Mudanças entre as edições de "Checklist Programação"

De UniWiki
Ir para: navegação, pesquisa
 
(20 revisões intermediárias por 3 usuários não estão sendo mostradas)
Linha 1: Linha 1:
[[Categoria:Desenvolvimento]]
+
'''ATENÇÃO! ESTÁ PÁGINA FOI MIGRADA PARA A WIKI NOVA E NÃO VAI SER MAIS ATUALIZADA AQUI, PARA CONFERIR: http://wiki.uniware.net.br/pt-br/Desenvolvimento/checklist-programacao'''
  
==Checklist de Programação==
 
  
Para manter um código padronizado e conciso,<br/>
+
[[Categoria:Desenvolvimento]]
a Uniware preparou as tabelas a seguir, que <br/>
 
auxiliam a garantir uma escrita comum entre <br/>
 
os colaboradores e as medidas preventivas  <br/>
 
antes de inserir alterações no software.    <br/>
 
esse documento é uma cópia de:
 
 
 
D:\CVS\documentos\Check-list programação.xls
 
 
 
===Padrões===
 
 
 
 
 
{| class="wikitable"
 
|-
 
|Nomeclatura de tabelas||Segue o prefixo {:alnum:}{:alnum:}*_ (2 caracterres e 1 ''underline'')<br/>
 
afim de identificar qual projeto a tabela pertence. Exemplos:<br/>
 
  
 +
=== Tópico desatualizado ===
 +
=== Transferido para o checklist da tarefa no Uniprojetos ===
 
{| class="wikitable"  
 
{| class="wikitable"  
 
|-  
 
|-  
|LB_ || Tabelas do Unilab
+
|Tab order
|-
+
|-
|SA_ || Tabelas do SAC
+
|está salvando no banco o que é informado (inclusão e alteração)?
|-
+
|-  
|FN_ || Tabelas do Financeiro do Unilab
+
|Está funcionando inclusão/alteração/exclusão e consulta?
|-
+
|-  
|HP_ || Tabelas importadas do Hermes Pardini
+
|maxlength correto para campos texto?
|-
+
|-  
|AL_ || Tabelas importadas do Álvaro
+
|Está obrigando o preenchimento dos campos corretos?
|-
+
|-  
|CR_ || Tabelas importadas do Criesp
+
|O usuário tem direito de executar. (F5 e F6 de seeker e botões)
|-
+
|-  
|SF_ || Tabelas importadas do Sérgio Franco
+
|campos novos estão na inclusão com cópia (se aplicável)
|-
+
|-  
|LOG_ || Tabelas de logs de alterações em outras Tabelas
+
|código fonte está no padrão da empresa
|-
+
|-  
|U2U_ || Interface Unilab
+
|os campos e tabelas criados estão no padrão de nomenclatura da empresa
|}
+
|-  
 
+
|É necessário corrigir dados do cliente na atualização?
|-
+
|-
|Nomeclatura de ''views''||Utiliza o prefixo {:alnum:}{:alnum:}*V . Exemplos:
+
|Incluir algum item no checklist para evitar o erro?
{| class="wikitable"
+
|-
 +
|Fez JOIN? - Confere se todos os campos da PK compõe o join
 +
|-  
 +
|Deixou de criar uma FK? - Tem que criar o índice, criou?
 +
|-
 +
|analisar o contexto onde ele está inserido e se outras partes do sistema podem estar com o mesmo bug.
 
|-  
 
|-  
|Nome || Aplicação || Principal Tabela da view
+
|Os forms que estão com Position=poDesktopCenter alterar para poMainFormCenter (se for tela cheia, poDesign)
|-
 
|LBVPEDI || Unilab || LB_PEDI
 
|-
 
|LBVEXAM || Unilab || LB_EXAM
 
|}
 
 
 
|-
 
|Nomeclatura de campos || Como prefixo, é adicionado uma caracter para definir seu tipo.
 
{| class="wikitable"
 
|-
 
|C|| Caracter
 
|-
 
|N|| Numérico
 
|-
 
|D|| Data e hora
 
|-
 
|E|| Enumerado
 
|}
 
IMPORTANTE: Não criar campos do tipo booleano, pois<br/>
 
esse tipo possui imcompatibilidade entre SGDB's. <br/>
 
Utilizar um Enumerado de S/N quando for necessário.
 
 
 
|-
 
|Tipos de campo || Alguns tipos de campos adotam um padrão em qualquer parte do sistema, são eles:
 
{| class="wikitable"
 
|-
 
|Monetário || DECIMAL(12,2);
 
|-
 
|Data, hora|| DATETIME;
 
|-
 
|Booleano || ENUM('S','N');
 
|}
 
 
 
|-
 
|Tamanho máximo de uma tela MDI || 1020x680
 
 
 
|-
 
|Nova Aplicação || Certificar-se de que:
 
#Todos os programadores possuem as ferramentas e compiladores necessários para dar manutenção.
 
#Criar uma pasta no ''subversion'' para a aplicação e a cada etapa efetivamente concluída, postar os fontes com uma descrição de acordo.
 
#Atualizar o artigo [[Aplicativos Uniware]]
 
*Quando a aplicação possuir uma versão de release, criar uma pasta no servidor com acesso para o suporte e disponibilizar os binários nela.
 
*Atualizar o artigo [[Aplicativos Uniware]]
 
 
 
|-
 
|Código fonte || Em Delphi, segue os seguintes padrões abaixo:
 
{| class="wikitable"
 
 
|-  
 
|-  
|Tipo || Padrão || Exemplo
+
|Quando for gravar data/hora em um campo, avaliar se é o caso de usar Só data (date) só hora (time) ou data e hora (datetime)
|-
 
|Constantes || Caixa alta, espaçamento com "_" || VALOR_PAGAMENTO_MINIMO
 
|-
 
|Variáveis, functions, procedures e nomes de classe|| Capitalizado || UmNomeBemGrandeColocarAPrimeiraLetraDeCadaPalavraEmMaiusculo
 
|-
 
|Variáveis de Classe || Iniciar com "F" || FCodiLab
 
|-
 
|Variáveis do DB || utilizar o mesmo nome do DB || TUnilabNumeroAmostra.CCODIPOST
 
|-
 
|Variáveis de function/procedure || Iniciar com "v" minúsculo || vVersao
 
|-
 
|Variáveis globais || Iniciar com "Global" || GlobalPostoColeta
 
|-
 
|Parâmetros (function/procedure) || Iniciar com "a" minúsculo || aCodiExpr
 
|-
 
|function/procedure aninhados || Iniciar com "_" || _PedidoAlterado
 
|-
 
|Classes (Tipos) || Iniciar com "T"  || TUnilabNumeroAmostra
 
|-
 
|Units || Iniciar com "U" || UUnilabNumeroAmostra
 
|-
 
|Forms || Iniciar com "F" || FExamesCad
 
|}
 
 
 
|-
 
|Tabulação || Padronizar em 2 espaços a tabulação.
 
|-
 
|Cores ||
 
* texto vermelho = $000000DD
 
* Fundo de form: $00e6e6e6
 
* Zebrado de relatório ou fundo cinza = clGrayZebra
 
* Texto azul = clBlue
 
|-
 
|Comentários || Como padrão de escrita segue o modelo com a forma de comentários do código:
 
 
 
''{Descrição da Unit}''
 
unit MyUnit;
 
interface
 
 
const
 
  ''{Descrição da Constante}''
 
  MyConstant = 4;
 
 
type
 
  ''{Descrição da Classe}''
 
  TMyClass = class
 
  public
 
    ''{Descrição da Variavel}''
 
    MyField: Integer;
 
    ''{Descrição do Método}''
 
    procedure MyMethod;
 
  end;
 
 
''{Descrição da Procedure}''
 
procedure MyProcedure;
 
 
implementation
 
 
procedure MyProcedure;
 
begin
 
 
  ''{ comentário do código }''
 
  if MyField = 0 then begin
 
   
 
    ''{ documentar aqui o propósito do SQL abaixo, e o que é
 
      cada campo documentar usando comentário de linha como segue }'' 
 
    SQL := 'CREATE TABLE X (    '+ // DESCRIÇÃO DA TABELA X
 
            ' CAMPO1 VARCHAR(171) '+ // DESCRIÇÃO DO CAMPO 1
 
            ' CAMPO2 INTEGER)     '; // DESCRIÇÃO DO CAMPO 2     
 
  end;
 
 
 
end;
 
 
end.
 
 
|}
 
|}
  
 
===Dependências/Impacto===
 
===Dependências/Impacto===
 
 
{| class="wikitable"  
 
{| class="wikitable"  
 +
|-
 +
|Group by||a coluna referenciada tem que constar como resultado da SQL. Senão o MySQL retorna resultados imprevisíveis.
 
|-  
 
|-  
 
|Quando usar uma das funções ao lado usar na ordem||
 
|Quando usar uma das funções ao lado usar na ordem||
Linha 181: Linha 52:
 
# - TransmissaoPedido ou AtualizaTransInfo
 
# - TransmissaoPedido ou AtualizaTransInfo
  
|-
+
 
  
 
|-  
 
|-  
Linha 192: Linha 63:
 
*ufExcluaDadosFinanceiro
 
*ufExcluaDadosFinanceiro
 
*ufPreparaMov
 
*ufPreparaMov
*ufManutencao.RecalculaUlibseq
+
*ufManutencao.btRecalculaClick
*ufManutencao.PreparaBaseCopiada
+
*ufManutencao.btPrepBaseCopiadaClick
 
*uTransmissao
 
*uTransmissao
*ufPostCad (CTRANSTRAN)
+
*UAuxGlobal(setTabelasComoTransmitidas - CTRANSTRAN)
 
*uTraduzirExcecao
 
*uTraduzirExcecao
 
*Dicionário de dados
 
*Dicionário de dados
Linha 293: Linha 164:
 
|-
 
|-
 
|Alterações na Estrutura do Banco de dados || Atualizar o dicionário de dados: D:\CVS\light\documentacao\Dicionário de Dados Unilab (v.2.0.2).mwb
 
|Alterações na Estrutura do Banco de dados || Atualizar o dicionário de dados: D:\CVS\light\documentacao\Dicionário de Dados Unilab (v.2.0.2).mwb
 
+
|-
 +
|Ao criar CPOSTOTRAN ou uma nova tabela com esse campo || Em UFPreparaMov tem uma função que marca esse campo com O, adicionar a tabela na lista também.
 +
|-
 +
|Criar serviço||Serviços deverão ter junto ao nome do serviço concatenado o nome da base gra service para ser instalado no datacenter teve que ser alterado de ultima hora pois ia ser instalado para o lida e ja estava para ourinhos
 +
|-
 +
|Incluir campo em tela Cad ou Sel|| No campo da query, atributo Título:
 +
*Tela CAD: deve ter o mesmo label do campo
 +
*Tela Sel: deve ter um descrição para o Filtra (se for um enumerado especificá-los, ex: Sexo do paciente [M]asculino, [F]eminino,  [I]gnorado)
 +
* Em tempo de execução se alterar a SQL não esquecer de setar o título também.
 +
|-
 +
|XML||
 +
* Não usar mais XMLParser, utilizar o comando obj := NewXML;
 +
* Sempre utilizar CDATA nos nossos XMLS quando um campo pode receber um & ou < ou >
 +
|-
 +
|Criar recurso na biblioteca||As units usada ou criadas devem ser incluidas na biblioteca afim de evitar de a biblioteca não compilar e evitar de criar referências cíclicas entre pacotes.
 +
|-
 +
|Updates em mais do que uma tabela || Respeitar a mesma ordem das tabelas da transmissão. Afim de evitar Deadlock entre rotinas.
 +
|-
 +
|PosSeek||Toda vez q um procedimento usar DE.PosSeek, lembrar de PosSave/PosLoad (c/try)
 +
|-
 +
|TUnilabPedido|| Ao utilizar campos da classe TUnilabPedido, verificar no método TUnilabPedido.Carrega se o campo está sendo carregado (ImportaPedido Unilab x Unilab)
 +
|-
 +
|É versão de letra?||Fazer o merge para o trunk!
 
|-
 
|-
 
|Revisão Final 1 - Hints e Warnings || Conferir os Hints e warnings gerados pelo Delphi e eliminá-los corrigindo os possíveis erros que eles podem estar indicando.  
 
|Revisão Final 1 - Hints e Warnings || Conferir os Hints e warnings gerados pelo Delphi e eliminá-los corrigindo os possíveis erros que eles podem estar indicando.  
 
 
|-  
 
|-  
|Revisão Final 2 - Dependências || olhar no diff cada função que foi alterada, e conferir no Pascal Browser se a mexida gera efeito colateral nas dependências.
+
|Revisão Final 2 - Teste de breakpoint || Olhar no diff e colocar um breakpoint em cada bloco alterado e rodar o programa debugando e conferindo o resultado da execução, se o programa fez o que era esperado.  
 
 
|-
 
|Revisão Final 3 - Teste de breakpoint || Olhar no diff e colocar um breakpoint em cada bloco alterado e rodar o programa debugando e conferindo o resultado da execução, se o programa fez o que era esperado.  
 
  
 
Cada breakpoint que ele passar e fizer o que é esperado, tirar o breakpoint até que todos os breakpoints sejam removidos.  
 
Cada breakpoint que ele passar e fizer o que é esperado, tirar o breakpoint até que todos os breakpoints sejam removidos.  
Linha 307: Linha 196:
 
O objetivo é testar todas as possibilidades englobadas pela alteração. Caso a implementação seja grande demais tornando esta etapa do checklist muito demorada, vamos conversar com o Cláudio e decidir se queremos dedicar tanto tempo conferindo aquela alteração.
 
O objetivo é testar todas as possibilidades englobadas pela alteração. Caso a implementação seja grande demais tornando esta etapa do checklist muito demorada, vamos conversar com o Cláudio e decidir se queremos dedicar tanto tempo conferindo aquela alteração.
  
 +
|-
 +
|Compilar todos os projetos || Unilab_BETA, Unilabw, Unilaudos, UnilabSRV_BETA,UnilabSRV, Unilab Consulta.
 
|-
 
|-
 
|Documentação do Ticket (UniSuite) || Não esquecer de colocar no Ticket a Analise, Notas de Teste e Notas da Versão (Copiar do Pivotal).
 
|Documentação do Ticket (UniSuite) || Não esquecer de colocar no Ticket a Analise, Notas de Teste e Notas da Versão (Copiar do Pivotal).
 +
|-
 +
 
|}
 
|}

Edição atual tal como às 09h30min de 17 de março de 2023

ATENÇÃO! ESTÁ PÁGINA FOI MIGRADA PARA A WIKI NOVA E NÃO VAI SER MAIS ATUALIZADA AQUI, PARA CONFERIR: http://wiki.uniware.net.br/pt-br/Desenvolvimento/checklist-programacao

Tópico desatualizado

Transferido para o checklist da tarefa no Uniprojetos

Tab order
está salvando no banco o que é informado (inclusão e alteração)?
Está funcionando inclusão/alteração/exclusão e consulta?
maxlength correto para campos texto?
Está obrigando o preenchimento dos campos corretos?
O usuário tem direito de executar. (F5 e F6 de seeker e botões)
campos novos estão na inclusão com cópia (se aplicável)
código fonte está no padrão da empresa
os campos e tabelas criados estão no padrão de nomenclatura da empresa
É necessário corrigir dados do cliente na atualização?
Incluir algum item no checklist para evitar o erro?
Fez JOIN? - Confere se todos os campos da PK compõe o join
Deixou de criar uma FK? - Tem que criar o índice, criou?
analisar o contexto onde ele está inserido e se outras partes do sistema podem estar com o mesmo bug.
Os forms que estão com Position=poDesktopCenter alterar para poMainFormCenter (se for tela cheia, poDesign)
Quando for gravar data/hora em um campo, avaliar se é o caso de usar Só data (date) só hora (time) ou data e hora (datetime)

Dependências/Impacto

Group by a coluna referenciada tem que constar como resultado da SQL. Senão o MySQL retorna resultados imprevisíveis.
Quando usar uma das funções ao lado usar na ordem
  1. - retistrastatus
  2. - StatusRPedido
  3. - MarcaPedidoParaEnvioINet
  4. - TransmissaoPedido ou AtualizaTransInfo


Permitiu ao posto de coleta alterar campo da expr. Na transmissão da expr do posto para a central tem que colocar um tratamento específico senão a informação não será transmitida.
Novo campo na LBVPEDI Criar o campo também na LBVPEDI_NAO_COLETADOS
Criação de nova tabela Verificar possíveis alterações em:
  • ufExcluaDados
  • ufExcluaDadosFinanceiro
  • ufPreparaMov
  • ufManutencao.btRecalculaClick
  • ufManutencao.btPrepBaseCopiadaClick
  • uTransmissao
  • UAuxGlobal(setTabelasComoTransmitidas - CTRANSTRAN)
  • uTraduzirExcecao
  • Dicionário de dados
Criação de chave Estrangeira Afim de evitar erros nos bancos MySQL hospedados em Linux, deve-se criar separadamente a tabela, a chave e a chave estrangeira. Exemplo:
CREATE TABLE LB_TESTE...
ALTER TABLE LB_TESTE
   ADD KEY FK_TESTE_CODI (CCODITESTE)
ALTER TABLE LB_TESTE
   ADD CONSTRAINT FK_TESTE_CODI FOREIGN KEY (CCODITESTE)
REFERENCES LB_OUTRO (CCODIOUTRO) 

Caso a chave estrangeira for relacionada com a tabela de exames, verificar TFExamRename.Processar.

Criar Campo na LB_EXAM Ao adicionar um novo campo na tabela:
  • Na tabela ULIBMETA criar um registro com o nome e definição do campo. (TFExamRelHistAlter depende desta tabela pra funcionar)
  • Verificar se para amostra adicional é necessário copiar o valor do campo do pai para os filhos: CADAntesCommit e CCODIPAIEXAMValidar
  • Ao Criar novos campos na LB_EXAM deve verificar as rotinas UFExamExporta e UFExamImporta para ver se o campo criado pode influenciar na rotina.
  • Verificar as rotinas de gravação do log de alteração do cadastro de exames (UFExamRelHistAlter) E seu respectivo relatório E se alteração implica na alteração da vigência do exame.
  • verificar a necessidade de incluir o novo campo no relatório do manual de exames (UFExamRelListaPApoiado).
  • Os campos devem ser replicados na função: VerificaAmostrasAdicionaisU2U. Esta função faz um insert no banco para incluir novas amostras adicionais, ou seja, insert na LB_EXAM.
Criar campo no configurador na CFEX Incluir carga do conteúdo do campo nos relatórios de lista de exames - UFResuRelLista, UFResuRelListaPaci

Para qualquer novo campo do configurador, incluir UCfgTab.TTabTipo. E tratar erro na carga do conteúdo das variáveis.

Alterar/Criar relatório de fatura Refletir alterações na exportação da fatura p/ excel
Criar nova Unit Verificar se precisa incluir também nos projetos: Unilabw, Unilab_BETA, Unilaudos e unilabSRV

Remover do delphi o autocreate que ele gera automaticamente para o form

Incluir Campo no TISS
  1. Incluir em todas as versões;
  2. Na impressão parcial/full;
  3. no configurador da guia full
Gravar datahora da coleta Rotinas que gravam coleta:
  • PediCad;
  • UfColeta;
  • UFDesfazColeta;
  • UFRecoleta;
  • UUnilabExpr;
  • PediImp (imprime mapa de não coletado ele põe a data de coleta auto);
  • TercLabCad (qdo inclui no lote um não coletado coleta auto);
Gravar datahora da triagem Rotinas que gravam triagem:
  • UFPedicad
  • UAuxGlobal
  • UFColeta
  • UFTriagem
  • UFRecoleta
  • UnilabExpr
  • UFTercLabCad
Incluída tabela na transmissão Constante: Versao_do_sistema_de_querypack - Incrementar quando tiver alteração nas funções queryPack e QueryUnPack

Versão do executável: em Project > Options > Version Info: Incrementar em qualquer nova versão

Versão do Unilab: A versão do Unilab do componente Sys da UFMain não é considerada pelo programa de transmissão. Mas a versão do executável é. Precisa recompilar o servidor de transmissão sempre que mudar a versão do Unilab.

Update na expr Sempre que fizer um update na expr incrementar a ulibrela
Novo Interfaceamento com Apoio/Equipamento
  • Recalcula Numero de amostra ufManutencao
  • cadastrar na tabela de recursos (UnilabWeb uw_recursos IDs 100 a 199).
  • Na Unit UControleUniware.pas, deve ser adicionada na procedure PublicarInformaoes a linha correspondente ao novo laboratório (procurar por #TAG_LABO).
  • Se a interface requer autorização implementar a geração da chave no ADM; na função Function InterfaceAutorizada() da Unit UFAutorizaInterface;
Campo chave tipo varchar Sempre ativar a propriedade UsaTrim do TUEdit Quando puder informar o valor do campo na mão
Alertas Sempre que fizer alguma modificação nos alertas dos exames:
  • Eles podem ser informados no cadastro de exame e cadastro de tabela de preços (UFExamValo e UFTabeCad).
  • Eles são exibidos no cadastro de pedidos e no orçamento.
Novo campo etiqueta
Inclusão de campos no configurador de etiquetas:
  • UFModEtiqCad (tela do novo configurador) - CarregaCampos: alterar constantes para listar campos disponíveis
  • UAuxModEtiq - TranslateNomeCampo & TranslateExemplo - descrição do campo no configurador e exemplo no visual da etiqueta
  • Para modelos etiq. carteirinha:
  • UFPaciEtiCart - PrintEtiquetas: Carrega os valores do banco ao imprimir a etiqueta
  • Para demais modelos:
  • UEtiqPrint - EtiquetasLoad: Carrega os valores do banco ao imprimir a etiqueta
Atualização com interação do usuário

Quando for executar uma rotina na UFAtualiza que precisa de alguma informação de usuário, chamar o procedimento na função TFAtualiza.Atualiza: assim a pergunta cai só no final da atualização. Assim agente pode 'deixar rodando' a atualização

Executar o UNILAB CONSULTA

Project -> Options -> directories/Conditionals -> Conditionals: incluir: xxxxxxxx " ;Ver_Print_Only "

Alterações na Estrutura do Banco de dados Atualizar o dicionário de dados: D:\CVS\light\documentacao\Dicionário de Dados Unilab (v.2.0.2).mwb
Ao criar CPOSTOTRAN ou uma nova tabela com esse campo Em UFPreparaMov tem uma função que marca esse campo com O, adicionar a tabela na lista também.
Criar serviço Serviços deverão ter junto ao nome do serviço concatenado o nome da base gra service para ser instalado no datacenter teve que ser alterado de ultima hora pois ia ser instalado para o lida e ja estava para ourinhos
Incluir campo em tela Cad ou Sel No campo da query, atributo Título:
  • Tela CAD: deve ter o mesmo label do campo
  • Tela Sel: deve ter um descrição para o Filtra (se for um enumerado especificá-los, ex: Sexo do paciente [M]asculino, [F]eminino, [I]gnorado)
  • Em tempo de execução se alterar a SQL não esquecer de setar o título também.
XML
  • Não usar mais XMLParser, utilizar o comando obj := NewXML;
  • Sempre utilizar CDATA nos nossos XMLS quando um campo pode receber um & ou < ou >
Criar recurso na biblioteca As units usada ou criadas devem ser incluidas na biblioteca afim de evitar de a biblioteca não compilar e evitar de criar referências cíclicas entre pacotes.
Updates em mais do que uma tabela Respeitar a mesma ordem das tabelas da transmissão. Afim de evitar Deadlock entre rotinas.
PosSeek Toda vez q um procedimento usar DE.PosSeek, lembrar de PosSave/PosLoad (c/try)
TUnilabPedido Ao utilizar campos da classe TUnilabPedido, verificar no método TUnilabPedido.Carrega se o campo está sendo carregado (ImportaPedido Unilab x Unilab)
É versão de letra? Fazer o merge para o trunk!
Revisão Final 1 - Hints e Warnings Conferir os Hints e warnings gerados pelo Delphi e eliminá-los corrigindo os possíveis erros que eles podem estar indicando.
Revisão Final 2 - Teste de breakpoint Olhar no diff e colocar um breakpoint em cada bloco alterado e rodar o programa debugando e conferindo o resultado da execução, se o programa fez o que era esperado.

Cada breakpoint que ele passar e fizer o que é esperado, tirar o breakpoint até que todos os breakpoints sejam removidos.

O objetivo é testar todas as possibilidades englobadas pela alteração. Caso a implementação seja grande demais tornando esta etapa do checklist muito demorada, vamos conversar com o Cláudio e decidir se queremos dedicar tanto tempo conferindo aquela alteração.

Compilar todos os projetos Unilab_BETA, Unilabw, Unilaudos, UnilabSRV_BETA,UnilabSRV, Unilab Consulta.
Documentação do Ticket (UniSuite) Não esquecer de colocar no Ticket a Analise, Notas de Teste e Notas da Versão (Copiar do Pivotal).