Skip to content

TDS Replay

DanielYampolschi edited this page Jan 11, 2021 · 41 revisions

TDSReplay 2.0

Vídeo Aula

Vídeo Aula

O TDSReplay é uma ferramenta investigativa que permite tirar uma foto do ERP TOTVS no momento exato de uma ocorrência, seja um erro de processamento ou execução, ou mesmo uma falha crítica que interrompa a execução do sistema.

Ele captura um conjunto de informações que permitirá a investigação pelo Suporte da TOTVS, sem a necessidade de montagens de ambiente, cópias de RPO ou Bancos de Dados.

O TDSReplay 2.0 foi aprimorado para acelerar e facilitar a obtenção das informações, e está disponível a partir das seguintes versões:

IMPORTANTE: A gravação do TDSReplay para o SmartClient WebApp (HTML) estará disponível para build de AppServer igual ou superior a 19.3.1.0

Obtendo os dados para investigação

Agora a obtenção dos dados poderá ser feita diretamente pelo usuário do sistema, da seguinte maneira:

  1. Acesse a rotina que deve ser investigada a partir do ERP TOTVS.

  2. Para iniciar a gravação da ocorrência pressione Shift+F6, abrindo o painel com as informações do sistema.

  3. Pressione o botão Avançar até selecionar a opção Rastrear Fontes.

  4. Confirme com o Suporte da TOTVS a necessidade de Gerar fontes de Lib, caso necessário marque a opção.

  5. Pressione o botão Iniciar, aguarde o início do processo, e pressione o botão Concluir.

  1. Execute a rotina até o ponto que reproduza a ocorrência / problema.

  2. Caso haja uma falha crítica que interrompa a execução do sistema, o arquivo será automaticamente salvo.

  3. Em qualquer outro caso de falha, como calculo, processo, etc, pressione novamente Shift+F6.

  4. Pressione o botão Avançar até Rastrear Fontes.

  5. Pressione o botão Finalizar.

  6. O arquivo com as informações será gerado na pasta do SmartClient de sua estação, como no exemplo abaixo.

  7. Anexe o arquivo gerado ao seu chamado.

  • .
  1. Por fim, caso ainda não tenha feito, pressione o botão Concluir no painel com as informações do sistema.

Investigando as informações coletadas

As informações obtidas serão utilizadas pelo Suporte da TOTVS durante a investigação.

Instalando o Executor do TDSReplay no VSCode

O TDSReplay faz parte do plugin tds-vscode, para mais informações acesse: https://marketplace.visualstudio.com/items?itemName=totvs.tds-vscode

Configurando o Executor

Para criar um executor do TDSReplay, pressione (ctrl + p no Windows / Linux ou command+p no Mac), e selecione a opção TDSReplay: Configure Launchers.

Atenção: Os executores do TDSReplay e do depurador convencional não são compatíveis.

TDSReplay Executor Command

Tela do Executor

TDSReplay Executor Screen

Campos do Executor:

  • Choose Launcher: Essa opção é uma caixa de seleção, caso necessite alterar um executor já cadastrado selecione o mesmo, caso esteja criando um novo, apenas digite seu nome.

  • File: Informe/Selecione o arquivo do TDSReplay obtido pelo cliente.

  • Password: Por padrão a senha será omitida durante a gravação dos dados, então deixe este campo em branco.

  • Include Sources: No momento do tratamento das informações é possível filtrar o conjunto de fontes que deseja importar.

    • utilize o curinga asterisco (*) para auxiliar no filtro, e a vírgula (,) como separador dos filtros, ex: FINA04*.PRW,MAT*03*, ou utilize um único asterisco (*) para importar todos os fontes, porém atente que este processo terá um grande impacto sobre o tempo de importação e sobre a performance da execução durante a investigação.

  • Exclude Sources: Essa opção permite filtrar o fontes que deseja ignorar durante a investigação, e aceita curingas da mesma maneira que o Include Sources.

  • Ignore sources not found in workspace (debugging): Essa opção vai omitir da Linha do Tempo os fontes que não estiverem disponíveis para investigação.

Pressione Save ou Save/Close, adicionando o executor arquivo arquivo launch.json e habilitando seu uso.

TDSReplay Executor Json

Analisando o arquivo

O primeiro passo é a importação do arquivo, que será feito uma única vez, em sua primeira execução.

Selecione na visão Run (no painel à esquerda) o executor que inseriu no passo anterior, ele estará disponível na caixa de seleção superior, conforme imagem anterior.

O VSCode irá apresentar uma notificação com o progresso, e também, na visão Output, irá exibir o progresso em modo texto.

O tempo de importação varia de acordo com o tamanho do arquivo gravado, e também com os filtros utilizados.

Import Progress

Após a o término da importação será exibida em uma nova aba a visão de Linha do Tempo, permitindo sua reposição em tela, como na imagem abaixo:

Time Line Example

A partir deste ponto o processo segue exatamente como um depuração convencional.

Note que ao utilizar um Step Over (ou F10) a linha correspondente da execução será posicionada também na visão de Linha do Tempo, da mesma forma, selecionando um item na Linha do Tempo a depuração irá selecionar a linha correspondente no código fonte.

Importante: Ao desabilitar a opção Ignore Source Not Found, os fontes não localizados serão exibidos na cor vermelha, apenas para informação, e não poderão ser selecionados. Note também o aumento no número de páginas da Linha do Tempo.

Ingore Source Not Found unchecked

Variáveis

Da mesma forma que a depuração convencional, os valores das variaveis são exibidos nos painéis Variables e Watches.

Importante: Não é possível executar expressões durante a depuração do TDSReplay, pois este processo é apenas uma "foto" do que aconteceu, e não está associado a um AppServer em execução.

Watch Variables

Caso um fonte tenha sido filtrado na importação, e uma variável teve seu valor atribuído nesse fonte, será exibida a mensagem: N/A (Value exists in a source that was filtered), como no exemplo abaixo.

Variable Filtered

Tabelas

As tabelas são apresentadas como um escopo de variáveis e podem ser acessadas como um array ou objeto.

É possível visualizar o conteúdo da tabela na visão **Expressions** apenas informando o nome dela.

A visão Debug Console também permite visualizar a tabela inteira, porém é preciso usar o comando: table:NOME_DA_TABELA

Também é possível visualizar o conteúdo de um campo usando a visão Expressions ou a visão Debug Console. Para isso deve-se usar o formato: TABELA->CAMPO

Clone this wiki locally