Keyboard shortcuts

Press or to navigate between chapters

Press S or / to search in the book

Press ? to show this help

Press Esc to hide this help

Como acessar

como_acessar_test_code.gif

O test code foi criado para que os desenvolvedores possam testar os Entry Points criados no banco de dados e funcionalidades do sistema, pois anteriormente era necessário inserir os códigos e configurações no Banco de Dados e executar pelo sistema, com o Test Code é possível centralizar a execução e testes para validação dos códigos e configurações.

Códigos de Exemplo

(acesse aqui para mais informações sobre DAO)

//Obter um único registro do banco pelo SEQ_DB:
$operacao = Dao::table('EQP_OPER')->seqDb(10);

// Criar um array com a chave sendo o SEQ_DB:
$records = Dao::table('EQP')->select('SEQ_DB')->get();
$seqDbList = array_column($records, null,'SEQ_DB');
print_r($seqDbList);

Exemplo de Alerts

(acesse aqui para mais informações sobre Alerts)

$$reportsService = new ReportsService();
$reportExportService = new ReportExportService();

$html = $reportsService->getHtmlReport('test_reports',['inicio'=>'03/10/2020','fim'=>'04/10/2020']);

/** 
 * O ultimo parametro no metodo generatePdfFile com o valor "true", 
 * define que o retorno serão metadados do arquivo ('filePath' e 'fileName'), 
 * necessario para enviar o pdf anexo no alerts
*/
$pdf = $reportExportService->generatePdfFile($html,[],'report1.pdf', true);
$pdf2 = $reportExportService->generatePdfFile($html,[],'report2.pdf', true);

$imagem = "";


$content = [];
$content['css'] = '';
$content['js'] = '';
$content['html'] = $html;
$content['image_base64'] = $imagem;
$additionalValues = [];
$additionalValues['CONTENT_JSON'] = json_encode($content);

ou 

$additionalValues['HTML'] = $html;
$additionalValues['IMAGE'] = $imagem;

....
$additionalValues['POSICAO_PLAT'] = -27.5527;
$additionalValues['POSICAO_PLON'] = -48.7296;
$additionalValues['SEND_EMAIL'] = 1;
$additionalValues['SEND_ALERTS'] = 0;
$additionalValues['SEND_EMAIL_PDF'] = 1;
$additionalValues['SEND_EMAIL_PDF_NAME'] = 'indicadores.pdf';
$additionalValues['SEND_EMAIL_IMAGE'] = 1;
$additionalValues['EMAIL_ATTACHMENTS'] = [$pdf,$pdf2];

$envio = Alerts::sendToUser('fabio.calegari@simova.com.br','Teste alerts '.date('d/m/Y H:i:s'), 'Teste',$additionalValues);
print_r($envio);

//sendToGroup
//sendToTopic

print_r($envio);

--> EXEMPLO COM INLINE FILES


// No template do test_reports tem: Logo com CID:<img src="cid:simova.png"> Esse nome simova.png é o criado na imagem abaixo e passado do 'file' para o array de in_line_files.

$reportsService = new ReportsService();
$html = $reportsService->getHtmlReport('test_reports',['inicio'=>'03/10/2020','fim'=>'04/10/2020']);

$exportUtils = new ExportUtils();

$pdf = $exportUtils->generatePdfFile($html,[],'report1.pdf');
$pdf2 = $exportUtils->generatePdfFile($html,[],'report2.pdf');

$imagem = "";

$imagenDentro = ImageService::createImageFileFromBase64($imagem,'simova.png');


$additionalValues['HTML'] = $html;
//$additionalValues['IMAGE'] = $imagem;

$additionalValues['SEND_EMAIL'] = 1;
$additionalValues['SEND_ALERTS'] = 0;
$additionalValues['SEND_EMAIL_PDF'] = 0;
$additionalValues['SEND_EMAIL_PDF_NAME'] = 'indicadores.pdf';
$additionalValues['SEND_EMAIL_IMAGE'] = 0;
$additionalValues['EMAIL_ATTACHMENTS'] = [$pdf,$pdf2];
$additionalValues['EMAIL_INLINE_FILES'] = [$imagenDentro['file']];

$envio = Alerts::sendToUser('fabio.calegari@simova.com.br','Teste alerts '.date('d/m/Y H:i:s'), 'Teste',$additionalValues);
print_r($envio);

Métodos da classe DateUtils

echo DateUtils::formatFromTable('2020-02-01 12:34:45'); // converte um campo de formato do banco de dados para BR com hora/minuto/segundo
echo DateUtils::formatFromTable('2020-02-01 12:34:45','d/m/Y'); // converte um campo de formato do banco de dados para BR somente d/m/y
echo DateUtils::formatFromTable('2020-02-01 12:34:45','H:i:s'); // converte um campo de formato do banco de dados para somente hora/minuto/segundo
echo DateUtils::formatFromTable('2020-02-01 12:34:45','H'); // converte um campo de formato do banco de dados para somente hora

var_dump(DateUtils::getDate());     // dia atual formato BR
var_dump(DateUtils::getDate(0,'BR'));     // dia atual formato BR (padrão)
var_dump(DateUtils::getDate(0,'DB'));     // dia atual formato Banco de dados
var_dump(DateUtils::getDate(0,'Y-m-d'));     // dia atual formato Banco de dados

var_dump(DateUtils::getDate(-1));   // dia anterior
var_dump(DateUtils::getDate(+1));   // amanhã
var_dump(DateUtils::getDate(-7));   // 7 dias atrás
var_dump(DateUtils::getDate(+7));   // 7 dias à frente

var_dump(DateUtils::getDateTime());     // dia atual
var_dump(DateUtils::getDateTime(-1));   // dia anterior

var_dump(DateUtils::getDateBetween());
var_dump(DateUtils::getDateBetween(-1));
var_dump(DateUtils::getDateBetween(+1,-27));
var_dump(DateUtils::getDateBetween(-7));
var_dump(DateUtils::getDateBetween(+7));

var_dump(DateUtils::getPeriodOfDay()); // somente o dia atual

// abordagem moderna:
list($inicioDb, $fimFimDb) = DateUtils::getDateBetween(-1,0,'DB');

// abordagem padrao para recuperar os valores da função:
$periodo = DateUtils::getDateBetween(-1,0,'DB',true);
$inicioDb = $periodo['INI'];
$fimFimDb = $periodo['FIM'];

Para simular uma request do xMova

$xmovaService = new XmovaService();


 Para consultar os dados que são montados diretamente em uma tabela (não considerando entryPoint):

$tableDS = 'EQP';
$sqlWhere = 'LIBERADO = 1'; //condição WHERE da consulta na tabela
 Atencao, para ordenar a lista ao XMova diferente do CRUD configurar um JSON no campo nfs_core_ds_tabela.ORDER_BY (ver documentacao) e VALIDAR O JSON ANTES!
$_recordsToMobileXMOVA = $xmovaService->getTableData($tableDS, $sqlWhere);
print_r($_recordsToMobileXMOVA);


 Se é um nome de entryPoint usar esse método abaixo:

$_typeRequest = 'Equipamento_Mobile'; // nome do entryPoint
$_objNFSJSONRequest
$method = 'LIST'; // ou pode ser GET (para validação de campos e retorno com json especificado
$_recordsToMobileXMOVA = $xmovaService->processEntryPointxMova($_typeRequest, $_objNFSJSONRequest, $method);
print_r($_recordsToMobileXMOVA);


Um recurso bem interessante é usar dois entryPoint com o mesmo nome mas com os tipos SQL e PHP
o Tipo SQL será executado primeiro e com isso no PHP você pode recuperar os dados de resultado do entryPoint PHP 
usando a variável $_recordsToMobileXMOVA e adicionando valores para ela, teste criando esses dois entryPoints e na versão PHP coloque:

foreach ($_recordsToMobileXMOVA as $row) {
	$row['DISPLAY_TEXT'] = $row['CODIGO'].PHP_EOL.$row['DESCRICAO'];
}

Métodos para consulta

$equipamentos = Dao::table('eqp')
			->groupBy('SEQ_DB')
			->toArray()
			->get();


// $lista = Dao::table('EQP')->get();                        
// var_dump($lista);                     
// $clientesList = Dao::table('FUNCIONARIO')
//                         ->select(['SEQ_DB','POSICAO_PLAT','POSICAO_PLON','POSICAO_DH','DESCRICAO','CODIGO','UPD_DH'])
//                         ->whereIsNotNull('POSICAO_PLAT')
//                         ->whereIsNotNull('POSICAO_PLON')
//                         ->limit(9999999)
//                         ->get();

// var_dump($clientesList);

/*
$tabela = xDS::getTabela('EQP');
$tabela = xDS::getTabela('FUNCIONARIO');
foreach ($tabela->CAMPOS as $campo) {
	echo $campo->NOME, " ", $campo->TIPO,"\n";
}
*/

// var_dump(\core\TabelaBO::getAllDataToArray("FUNCIONARIO","SEQ_DB"));

/**
* Usando o NfsQueryBuilder:
* Abordagem IDEAL que contém tratamento se parametro for null
*/
$inicioDb = '2020-09-17';
$fimFimDb = '2020-09-17 23:59:59';
$result = NFSQueryBuilder::select('*')
	->from('eqp_apt', 'apt')
	->where('apt.INI_DH between :inicio and :fim')
	->setParameter('inicio', $inicioDb)
	->setParameter('fim', $fimFimDb)
	->get();

var_dump($result);

// OU assim:
$result = NFSQueryBuilder::select('*')
	->from('eqp_apt', 'apt')
	->where("apt.INI_DH between '{$inicioDb}' and '{$fimFimDb}'")
	->get();

// OU assim:
$where = "apt.INI_DH between '".$inicioDb."' and '".$fimFimDb."'";
$result = NFSQueryBuilder::select('*')
	->from('eqp_apt', 'apt')
	->where($where)
	->get();


Testando o JSON de um NfsQueryBuilder (configuração de gráfico ou relatório):
 Pode ser JSON ou pode ser um Array

$json = '{	"equipamentos": {
		"select": ["eqp.SEQ_DB","eqp.EQP_CLASSE_SEQ_DB",
			"eqp.CODIGO",
			"eqp.DESCRICAO"
		],
		"from": "eqp eqp",
		"group_result_by_unique": "SEQ_DB",
		"order_by": [
			["eqp.SEQ_DB", "ASC"]
		]
	}
}';
$array = json_decode($json, true);
var_dump(\core\NFSQueryBuilder::getQuery($array));

Debugando o NfsQueryBuilder

$_SESSION['DEBUG_MODE'] = 1;
print_r($_SESSION['DEBUG_CONFIG']);
print_r($_SESSION['DEBUG_PARAMS']);
print_r($_SESSION['DEBUG_SQL']);

/**
* Debugando UM gráfico do Dashboard
* Crie um painel de teste e defina somente UM gráfico para esse painel
*/
$_SESSION['DEBUG_MODE'] = 1;
print_r($_SESSION['DEBUG_CONFIG']);
print_r($_SESSION['DEBUG_FILTERS_VALUES']);
print_r($_SESSION['DEBUG_FILTERS_CONFIG']);
print_r($_SESSION['DEBUG_FILTERS_AND_VALUES']);
print_r($_SESSION['DEBUG_DATA']);


// Alerts::sendToGroup('GRUPO_TESTE','Titulo','Texto');
// Alerts::sendToUser('email@xxxx.com.br','Titulo','Texto');
// Alerts::sendToTopic('TOPICO_TESTE','Titulo','Texto');
// Alerts::sendToUsers(['email@xxxx.com.br','email2222@xxxx.com.br'],'Titulo','Texto');  // AINDA NAO FUNCIONA

$destinatario = 'fabio.calegari@simova.com.br'; // usuário ativo/cadastrado (tabela alerts_users)
$titulo = 'Titulo do Alerta (até 50 caracteres) '; // o core corta automaticamente e pega somente os primeiros 50 bytes
$texto = 'Texto do Alerta (até 1000 caracteres)'; // o core corta automaticamente e pega somente os primeiros 1000 bytes
$retornoDoEnvio = Alerts::sendToUser($destinatario, $titulo, $texto);

print_r($retornoDoEnvio);

Upload de Base64 - UploadService

$seqDbUpload = UploadService::uploadBase64("data:image/jpeg;base64,".$myBase64Url);

print_r($seqDbUpload);