tko: Test Kit Operations
Project description
- Instalação
- Dependências
- Download atividades
- Rodando
- Utilizando outras linguagens de programação
- Verificando o resultado
- O que é um teste?
- Convertendo entre formatos
tko
O TKO é um sistema de testes para programação competitiva. Ele é capaz de rodar testes em várias linguagens de programação e em vários formatos de testes. Ele está integrado com os repositórios de atividades das disciplinas de programação da UFC de Quixadá permitindo baixar as atividades e rodar os testes.
Instalação
Windows | Linux | Replit | Codespace |
---|---|---|---|
# instalar utilizando o gerenciador de pacotes do python
pip install tko
# ou diretamente pelo github
pip install git+https://github.com/senapk/tko.git
Dependências
Você precisará do compilador próprio da linguagem que for programar, instale manualmente no seu sistema. Se estiver no replit, o template da linguagem já vem com o compilador instalado.
- c/c++:
gcc
oug++
- java:
javac
- python:
python3
- javascript:
node
- typescript:
esbuild
enode
Download atividades
- Para baixar, por exemplo, a atividade do carro do repositório de POO(Programação Orientada a Objetos): contrua seu primeiro @carro para
java
:
# Você informa o repositório `poo` o problema `carro` e vai ser perguntado a linguagem interativamente
# tko down _course _activity
tko down poo carro
# você pode também especificar a linguagem para pular o prompt
tko down poo carro -l java
# ou pode definir a linguagem padrão de download dos rascunhos para não precisar informar toda vez
tko config -l java
Ao baixar a questão, você terá uma pasta com o nome carro
contendo:
- Readme.md: com a descrição da atividade em markdown.
- cases.tio: com os casos de teste.
- draft.ext: com o rascunho da solução.
Rodando
Rodando sem testar
Após baixar, entre na pasta.
Você pode aproveitar o arquivo de rascunho e renomeá-lo, ou criar seus próprios arquivos de resposta ao problema.
Para executar seu arquivo sem testar, basta rodar o comando tko run
passando o arquivo de código como parâmetro.
Por exemplo, para a linguagem Java, você pode rodar o seguinte comando:
# tko run _arquivo_de_codigo
tko run Solver.java
A ferramenta vai compilar e executar seu código, mostrando se houve algum erro.
Rodando os testes
Para rodar os testes, passe também o arquivo de testes cases.tio
em qualquer ordem, antes ou depois do seu arquivo de código para o comando.
# tko run _arquivos_de_codigo _arquivo_de_casos_de_teste
tko run Solver.java cases.tio
Descompactando os testes
Se preferir trabalhar com o modelo de testes em arquivos separados, você pode descompactar o arquivo cases.tio
para uma pasta com os arquivos de entrada e saída. Será gerado um arquivo .in
e um .sol
para cada teste.
$ mkdir pasta
$ tko build pasta cases.tio
$ ls pasta
00.in 00.sol 01.in 01.sol 02.in 02.sol 03.in 03.sol 04.in 04.sol
Para rodar a partir da pasta com os testes descompactados, basta passar o nome da pasta como parâmetro.
tko run Solver.java pasta
Se quiser utilizar um nome padrão diferente para leitura ou escrita das pastas, veja a seção de Convertendo entre formatos.
Rodando múltiplos arquivos
Se você tiver mais de um arquivo de código, o comportamento depende da linguagem.
Java
Se estiver executando tko
de dentro da pasta. Basta executar o arquivo que contém a main
. No exemplo abaixo, tanto a classe Shell
quanto a classe Motorcycle
contém a main
. A classe Shell
é usada para rodar junto com o cases.tio
, para interpretar os testes. A classe Motorcycle
é usada para rodar sem testes.
[lion@jungle java]$ ls
Adapter.java cases.tio Motorcycle.java Person.java Shell.java
[lion@jungle java]$ tko run Shell.java cases.tio
═══════════════════════════ Running solver against test cases ═══════════════════════════
=> base:[cases.tio(15)] prog:[Shell.java] [✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓]
[lion@jungle java]$ tko run Motorcycle.java
─────────── No test cases found. Running: java -cp /tmp/tmph43lgfhb Motorcycle ──────────
Rodando a main do arquivo da motoca
[lion@jungle java]$
C e C++
- Você precisa passar todos os arquivo
c
oucpp
que deseja compilar e rodar. - A ordem dos arquivos não importa, mas apenas um deles pode ter a função
main
. - No exemplo abaixo, o arquivo
main.cpp
é o arquivo que contém amain
e o arquivopoint.cpp
contém as implementação das funções que serão usadas no arquivomain.cpp
.
[lion@jungle cpp]$ ls
cases.tio fn.hpp main.cpp point.cpp point.hpp
[lion@jungle cpp]$ tko run *.cpp cases.tio
═══════════════════════════ Running solver against test cases ═══════════════════════════
=> base:[cases.tio(02)] prog:[main.cpp, point.cpp] [✓ ✓]
Typescript e Javascript
- Você precisa passar todos os arquivo
ts
oujs
que deseja compilar e rodar. Exemplo - O primeiro arquivo
.ts
passado por parâmetro é o arquivo que vai ser executado. - Opção 1: Você pode escolher o arquivo principal, antes de passar os outros arquivos.
tko run cases.tio shell.ts adapter.ts motoca.ts pessoa.ts
- Opção 2: Você pode passar o arquivo principal primeiro e depois utilizar o
*.ts
para os outros.tko run cases.tio shell.ts *.ts
- Opção 3: Você pode renomear o arquivo principal para um nome que esteja "antes" dos outros.
mv shell.ts aashell.ts
tko run cases.tio *.ts
Exemplos: Typescript e Javascript
[lion@jungle ts]$ ls
adapter.ts cases.tio motoca.ts pessoa.ts shell.ts
##########################################
# PASSANDO OS ARQUIVOS SEM USAR WILDCARD *
[lion@jungle ts]$ tko run cases.tio shell.ts adapter.ts motoca.ts pessoa.ts
═══════════════════════════ Running solver against test cases ═══════════════════════════
=> base:[cases.tio(15)] prog:[shell.ts, adapter.ts, motoca.ts, pessoa.ts] [✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓]
##########################################
# PASSANDO O ARQUIVO PRINCIPAL PRIMEIRO E DEPOIS OS OUTROS
[lion@jungle ts]$ tko run cases.tio shell.ts *.ts
═══════════════════════════ Running solver against test cases ═══════════════════════════
=> base:[cases.tio(15)] prog:[shell.ts, adapter.ts, motoca.ts, pessoa.ts] [✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓]
##########################################
# MUDANDO O NOME DO SHELL PARA AASHELL
[lion@jungle ts]$ mv shell.ts aashell.ts
[lion@jungle ts]$ tko run cases.tio *.ts
═══════════════════════════ Running solver against test cases ═══════════════════════════
=> base:[cases.tio(15)] prog:[aashell.ts, adapter.ts, motoca.ts, pessoa.ts] [✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓ ✓]
Se algum módulo quiser ser executado individualmente, ele pode ter o seguinte bloco de código:
export { Motoca };
// esse if garante que o módulo só vai ser executado se for chamado diretamente
if (module === require.main) {
let moto = new Motoca(2);
console.log(moto.toString());
moto.inserir(new Pessoa("jose", 9));
console.log(moto.toString());
}
E pode ser executado passando o arquivo diretamente:
[lion@jungle ts]$ tko run motoca.ts pessoa.ts
────────── No test cases found. Running: node /tmp/tmp2yhb8xem/motoca.js ──────────
power:2, time:0, person:(empty)
power:2, time:0, person:(jose:9)
Utilizando outras linguagens de programação
Opção 1: chamando o interpretador da linguagem
Códigos em lua
podem ser executados por um interpretador, tal qual python
e javascript
.
Seja o seguinte código
// teste.lua
print("Hello World")
- Podemos mostrar ao
tko
qual comando executar com a flag--cmd
:tko run --cmd "lua teste.lua" cases.tio
Compilando antecipadamente
Se sua linguagem gera código executável, tal qual c
, c++
ou rust
você pode compilar e passar o executável para o tko
. Vamos ver um exemplo em c++
, compilado manualmente.
- compilação:
g++ -std=c++20 -Wall teste.cpp -o teste.out
- teste:
tko run teste.out cases.tio
Verificando o resultado
Após fazer uma parte do código, executamos os testes novamente. Agora ele compila e mostra:
- Quantos testes passaram.
- O nome e o índice dos testes que falharam.
- O diff do primeiro teste que falhou
- resultado esperado (lado esquerdo), resultado obtido (lado direito).
- O diff da primeira linha diferente renderizando os whitespaces.
Opções extras
- É muito útil na hora de debugar, isolar o teste que você está trabalhando. Caso queira rodar apenas um índice de teste, utilize a opção
-i
:
# rodando apenas o teste 5 depois de encher o código de print para debugar
tko run Solver.java cases.tio -i 5
$ tko config --help
options:
-h, --help show this help message and exit
--ascii set ascii mode.
--unicode set unicode mode.
--color set colored mode.
--mono set mono mode.
--side set side_by_side diff mode.
--down set up_to_down diff mode.
--lang ext, -l ext set default language extension.
--ask ask language extension every time.
--root set root path for tko down
Vou definir a cor para monocromático, diff down
e a linguagem padrão para js
.
$ tko config --mono
Color mode now is: MONOCHROMATIC
$ tko config --down
Diff mode now is: UP_DOWN
$ tko config -l js
Default language extension now is: js
O que é um teste?
- Um teste define qual o comportamento esperado de um programa determinístico. Para uma determinada entrada, o programa deve gerar sempre a mesma saída.
- A entrada e saída e o comportamento esperado devem ser bem definidos, por exemplo:
- Dados dois números inteiros de entrada, um por linha, mostre o resultado da divisão. Se o resultado for inteiro, mostre o valor inteiro, se for flutuante, mostre com duas casas decimais.
Formatos de teste
- Um arquivo de texto com vários testes:
- modelo TIO(test input output).
- modelo VPL que é utilizado no plugin do moodle.
- Uma pasta com um dois arquivos para cada teste, um arquivo com a entrada e outro com a saída.
- modelo maratona:
- Arquivos .in e .out
- Arquivos .in e .sol
- modelo maratona:
Sintaxe TIO
>>>>>>>>
entrada
...
========
saída
...
<<<<<<<<
>>>>>>>>
entrada
...
========
saída
...
<<<<<<<<
Escrevendo alguns testes
Vamos escrever alguns testes para o problema proposto. Crie um arquivo chamado testes.tio
e vamos inserir algumas entradas para o problema proposto.
>>>>>>>>
4
2
========
2
<<<<<<<<
>>>>>>>>
3
2
========
1.50
<<<<<<<<
>>>>>>>>
5
4
========
1.25
<<<<<<<<
>>>>>>>>
1
3
========
0.33
<<<<<<<<
Convertendo entre formatos
- Gerando um
t.vpl
tko build t.vpl testes.tio
- Gerando um
t.tio
a partir doReadme.md
e de umextra.tio
.tko build t.tio Readme.md extra.tio
- Para extrair os testes para uma pasta com um arquivo para entrada e outro para saída, crie uma pasta vazia e passe para o primeiro parâmetro do
tko build
.
$ ls
cases.tio draft.c Readme.md
$ mkdir pasta
$ tko build pasta cases.tio
$ ls pasta/
00.in 02.sol 05.in 07.sol 10.in 12.sol 15.in 17.sol 20.in 22.sol
00.sol 03.in 05.sol 08.in 10.sol 13.in 15.sol 18.in 20.sol 23.in
01.in 03.sol 06.in 08.sol 11.in 13.sol 16.in 18.sol 21.in 23.sol
01.sol 04.in 06.sol 09.in 11.sol 14.in 16.sol 19.in 21.sol
02.in 04.sol 07.in 09.sol 12.in 14.sol 17.in 19.sol 22.in
- Você pode definir o padrão de nome dos arquivos gerados com
-p "@ @"
, sendo @ o wildcard que representa a numeração dos arquivo.- Vamos refazer o comando acima, mas colocando "-p in.@ out.@"
$ tko build pasta/ cases.tio -p "in.@ out.@"
$ ls pasta/
in.00 in.05 in.10 in.15 in.20 out.01 out.06 out.11 out.16 out.21
in.01 in.06 in.11 in.16 in.21 out.02 out.07 out.12 out.17 out.22
in.02 in.07 in.12 in.17 in.22 out.03 out.08 out.13 out.18 out.23
in.03 in.08 in.13 in.18 in.23 out.04 out.09 out.14 out.19
in.04 in.09 in.14 in.19 out.00 out.05 out.10 out.15 out.20
- O
pattern
é útil para converter os formatos de Maratona, que vem em múltiplos arquivos para o.tio
. Basta fazer omatch
do modelo que eles utilizarem.-p "@.in @.out"
-p "in@ out@"
- entre outros.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file tko-0.11.5.tar.gz
.
File metadata
- Download URL: tko-0.11.5.tar.gz
- Upload date:
- Size: 67.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 70f2aeeb0d17451cc32712d5288e0c67f1a23fc1a510dffe7bd930687b0e1bd9 |
|
MD5 | f3b882bfed9f0692c19d8e074a852d03 |
|
BLAKE2b-256 | 48e7a7b3a96067494bbb06dc2da7b0a683a4eed1eceb3af5553a98295f39f227 |
File details
Details for the file tko-0.11.5-py3-none-any.whl
.
File metadata
- Download URL: tko-0.11.5-py3-none-any.whl
- Upload date:
- Size: 68.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e329093dbaf34fa460ac4336725e5de81dd743aa21a768a2cd354fd40d1305f9 |
|
MD5 | afbc3e201cd4bf7ac5ae9149386dc6e3 |
|
BLAKE2b-256 | 9aea9279fdd9f77f6f40a02f7a3c20f28834dcacaeeb4ddabcd5e7d856d9c7f1 |