No project description provided
Project description
Leetcode-local-tester
Leetcode test utils for local environment
Background
Because of Leetcode's special design for test cases, if you want to test your code locally, you need to write some boilerplate code to read the test cases from the file and parse them into the format that your code can understand, which is very annoying. Especially in a contest, you may not have enough time to write the boilerplate code. So I wrote this tool to help me generate the boilerplate code automatically. It will improve your efficiency in a contest.
The design is really like TopCoder's test cases, but TopCoder has a very good tool (TZTester) to generate the boilerplate code for you, which is very convenient.
Usage
Install
pip install leetcode-local-tester
Command
leetcode-local-tester work --help
Options:
--kind TEXT The question kind. Now support: `contest`, `problem`,
`season`, and `contest` includes `weekly` and
`biweekly`. Default is `problem`.
--detail TEXT The detail of the question. If type is `contest` or
`problem`, the detail is the url. Such as
`https://leetcode.com/contest/weekly-contest-326/`,
`https://leetcode.cn/problems/minimum-number-of-
operations-to-reinitialize-a-permutation/`. If type is
`season`, the detail is the season name. Such as
`2020-fall-solo` or `2020-fall-team`.
--language TEXT The language of the code. Now support: `cpp`,
`python3`. Default is `python3`.
--location TEXT The location of the code. Default is `./leetcode/`.
--help Show this message and exit.
Before you use
Because the utility needs to login to Leetcode to get some information, there are two ways to login. One is to use username and password. You need to set these value to environment variables: LEETCODE_USERNAME
and LEETCODE_PASSWORD
. The other is to use cookie. You need to set the cookie to environment variable: LEETCODE_COOKIE
. You can read the article How to get the cookie to get the cookie.
- Note: If you use
leetcode.com
. You cannot use username and password to login, becauseleetcode.com
has recaptcha. So you need to use cookie to login.
Example
leetcode-local-tester work --kind contest --detail https://leetcode.com/contest/weekly-contest-326/ --language cpp --location ./leetcode/
After running the command, you will get the following files:
weekly-contest-326
: The folder of the contest. It contains all test cases and the code file.
utils
: The folder of the utils. It contains code that is used to parse the test cases.
Pay attention: utils
folder is only generated once. After generated the first time, it will not be updated. So you can add your own code in it.
You can write your code in solution.h
. We take the first question in weekly-contest-300
as an example.
The solution.h
file is like this:
/*
Code generated by https://github.com/goodstudyqaq/leetcode-local-tester
*/
#if __has_include("../utils/cpp/help.hpp")
#include "../utils/cpp/help.hpp"
#elif __has_include("../../utils/cpp/help.hpp")
#include "../../utils/cpp/help.hpp"
#else
#define debug(...) 42
#endif
class Solution {
public:
string decodeMessage(string key, string message) {
int res[26];
memset(res, -1, sizeof(res));
int cnt = 0;
for (auto v : key) {
int cur = v - 'a';
if (cur >= 0 && cur < 26) {
if (res[cur] != -1) continue;
res[cur] = cnt++;
}
}
string fin;
for (auto v : message) {
if (v == ' ')
fin += ' ';
else {
char cur = 'a' + res[v - 'a'];
fin += cur;
}
}
return fin;
}
};
After you finish your own code, you can run main.cpp
to test your code.
g++ main.cpp -std=c++11 -o main && ./main
Case 1 testing...
[my_ans]: "this is a secret"
[result]: "this is a secret"
Case 1 passed!
Case 2 testing...
[my_ans]: "the five boxing wizards jump quickly"
[result]: "the five boxing wizards jump quickly"
Case 2 passed!
The number of test cases: 2
The number of test cases failed: 0
If you get Wrong answer
, you can snip the test case and paste it into data
to debug your code.
Pay attention: data
's format is Input + Output.
In this example, the test case is:
"the quick brown fox jumps over the lazy dog"
"vkbs bs t suepuv"
TODO
- Support
python
(completed)
License
This software is licensed under the MIT License. See the LICENSE file in the top distribution directory for the full license text.
Maintaining the project is hard and time-consuming, and I've put much ❤️ and effort into this.
If you've appreciated my work, you can back me up with a donation! Thank you 😊
If there is any problem, please create an issue. I will reply to you as soon as possible.
Project details
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 leetcode_local_tester-0.5.0.tar.gz
.
File metadata
- Download URL: leetcode_local_tester-0.5.0.tar.gz
- Upload date:
- Size: 23.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.6.1 CPython/3.9.13 Darwin/22.3.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e84b4f251f2f727d44792a53fb232cac4223395886dbf095a9f15099cfb95635 |
|
MD5 | 1592e40320bc7153690d9909c33818b1 |
|
BLAKE2b-256 | 5b3d5d2428801a5d4793ba8527dbc480970f6ccde74edc58a9a1f7924344544c |
File details
Details for the file leetcode_local_tester-0.5.0-py3-none-any.whl
.
File metadata
- Download URL: leetcode_local_tester-0.5.0-py3-none-any.whl
- Upload date:
- Size: 31.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.6.1 CPython/3.9.13 Darwin/22.3.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7d35bcda48ca9bf71c9137a7d51710e4fa76678e56da3b87c5f1c4f3c54791d7 |
|
MD5 | c808133a0ade2044173044ddf809eec2 |
|
BLAKE2b-256 | 1ac92242550f02cc9e1a278226da3e0d025839047029751d578434a5f621ae61 |