As a problem solver, sometimes you might have slow internet, and waiting until your submission get tested might take longer than expected, you might even refresh your page a lot of times.
so why not testing your solution locally before you submit it?
Hakam’s name derives from “حَكَم” which is an arabic word means judge, and it is pronounced as /ħakam/. but since there is no /ħ/ sound in english i just latinised the name as “Hakam”.
Any language that supports stdin
& stdout
.
git clone --depth 1 https://github.com/iahmadgad/hakam.git && cd hakam && make install
Hakamfile is a json file Hakam uses to compile، execute, and then test your solution code.
Here is an example of a Hakamfile:
{
"compile": "g++ solution.cpp",
"execute": "./a.out",
"tests":
[
["8", "YES"],
["5", "NO"]
]
}
compile
is the command used to compile your code before excuting it. in case your language is interpreted like Python you can just delete this key.
execute
is the command used to execute your code. it is required.
tests
is an array of 2-element arrays, where each [0] index of them is the input and the [1] index is the expected output, i.e. the right answer. it is required.
hakam [-h] {new,set,add,rm,test} ...
[-h, --help]
prints usage
set [-h] [-f, --filename FILENAME] [-c, --compile command] [-e, --execute command] [-t, --tests number]
[-f, --filename FILENAME]
: name of file to set values, if not given set values in file named hakamfile.json
.[-c, --compile command]
: command used to compile your code.[-e, --execute command]
: command used to execute your code.[-t, --tests number]
: number of tests, if given, Hakam will prompt you for each input & output, this will override any previous tests, if you already have tests and you want to add more, then use add
instead.add [-h] [-f, --filename FILENAME] [-c, --compile command] [-t, --tests number]
[-f, --filename FILENAME]
: name of files to add values, if not given add values to file named hakamfile.json
.[-c, --compile command]
: command used to compile your code.[-t, --tests number]
: number of tests, if given, Hakam will prompt you for each input & output, this won’t override any previous tests.rm [-h] [-f, --filename FILENAME] [-c, --compile command] [-t, --test index]
[-f, --filename FILENAME]
: name of file to delete values from, if not given delete values from file named hakamfile.json
.[-c, --compile]
: command used to compile your code.[-t, --test index]
: index of test to delete, index begins from 1 not 0.test [-f, --filename FILENAME] [-s, --strict] [-v, --verbose]
[-f, --filename FILENAME]
: test file named [FILENAME]
, if not given test file named hakamfile.json
.[-s, --strict]
: exit if code answered wrong or if runtime error is thrown.[-v, --verbose]
print tests & results.
Output should be something like this:$ hakam test
Compiling...
Testing...
Passed: 2
Wrong answers: 1
with --verbose
:
$ hakam test --verbose
Compiling...
Testing...
1: Test Passed :)
2: Test Passed :)
3: Wrong Answer :^)
expected NO for input 2 not YES
Passed: 2
Wrong answers: 1
In case your code passed all the tests output should be something like this:
$ hakam test
Compiling...
Testing...
Accepted
with --verbose
:
$ hakam test --verbose
Compiling...
Testing...
1: Test Passed :)
2: Test Passed :)
3: Test Passed :)
Accepted
In case your code answered wrong and you chose --strict
option, Hakam won’t proceed to perform tests, and output should be something like this:
hakam test --strict
Compiling...
Testing...
1: Wrong Answer :^)
expected YES for input 8 not NO