[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
06/13: gnu: Add online-judge-tools.
From: |
guix-commits |
Subject: |
06/13: gnu: Add online-judge-tools. |
Date: |
Mon, 30 Oct 2023 07:19:54 -0400 (EDT) |
cbaines pushed a commit to branch master
in repository guix.
commit 789ef6837f9794c02bc53a854aacfdf04d3384cf
Author: gemmaro <gemmaro.dev@gmail.com>
AuthorDate: Sat Aug 26 15:22:41 2023 +0900
gnu: Add online-judge-tools.
* gnu/packages/python-xyz.scm (online-judge-tools): New variable.
* gnu/packages/patches/online-judge-tools.patch: New file.
* gnu/local.mk (dist_patch_DATA): Add patch file.
Signed-off-by: Christopher Baines <mail@cbaines.net>
Change-Id: I78315db15ca8205dff607e98388c404ede64fb60
---
gnu/local.mk | 1 +
gnu/packages/patches/online-judge-tools.patch | 62 +++++++++++++++++++++++++++
gnu/packages/python-xyz.scm | 35 +++++++++++++++
3 files changed, 98 insertions(+)
diff --git a/gnu/local.mk b/gnu/local.mk
index 8518c91268..8d817379a7 100644
--- a/gnu/local.mk
+++ b/gnu/local.mk
@@ -1703,6 +1703,7 @@ dist_patch_DATA =
\
%D%/packages/patches/omake-fix-non-determinism.patch \
%D%/packages/patches/oneko-remove-nonfree-characters.patch \
%D%/packages/patches/onionshare-cli-async-mode.patch \
+ %D%/packages/patches/online-judge-tools.patch \
%D%/packages/patches/onnx-optimizer-system-library.patch \
%D%/packages/patches/onnx-use-system-googletest.patch \
%D%/packages/patches/onnx-shared-libraries.patch \
diff --git a/gnu/packages/patches/online-judge-tools.patch
b/gnu/packages/patches/online-judge-tools.patch
new file mode 100644
index 0000000000..9e016d7104
--- /dev/null
+++ b/gnu/packages/patches/online-judge-tools.patch
@@ -0,0 +1,62 @@
+Skip failing tests and an assertion. The skipped tests require network
+connections.
+
+--- a/tests/command_download.py
++++ b/tests/command_download.py
+@@ -90,6 +90,7 @@ class DownloadTest(unittest.TestCase):
+ def snippet_call_download_failure(self, *args, **kwargs):
+ tests.command_download.snippet_call_download_failure(self, *args,
**kwargs)
+
++ @unittest.skip("Disabled by Guix")
+ def test_call_download_atcoder_abc114_c(self):
+
self.snippet_call_download('https://atcoder.jp/contests/abc114/tasks/abc114_c',
[
+ {
+@@ -106,6 +107,7 @@ class DownloadTest(unittest.TestCase):
+ },
+ ], type='json')
+
++ @unittest.skip("Disabled by Guix")
+ def test_call_download_atcoder_abc003_4(self):
+
self.snippet_call_download('https://atcoder.jp/contests/abc003/tasks/abc003_4',
[
+ {
+@@ -126,9 +128,11 @@ class DownloadTest(unittest.TestCase):
+ },
+ ], type='json')
+
++ @unittest.skip("Disabled by Guix")
+ def test_call_download_invalid_url(self):
+
self.snippet_call_download_failure('http://abc001.contest.atcoder.jp/tasks/abc001_100')
+
++ @unittest.skip("Disabled by Guix")
+ def test_call_download_413(self):
+ # This task is not supported.
+
self.snippet_call_download_failure('https://chokudai001.contest.atcoder.jp/tasks/chokudai_001_a')
+@@ -141,13 +145,16 @@ class DownloadInvalidTest(unittest.TestCase):
+ def snippet_call_download_twice(self, *args, **kwargs):
+ tests.command_download.snippet_call_download_twice(self, *args,
**kwargs)
+
++ @unittest.skip("Disabled by Guix")
+ def test_call_download_invalid(self):
+
self.snippet_call_download_failure('https://not_exist_contest.jp/tasks/001_a')
+
++ @unittest.skip("Disabled by Guix")
+ def test_call_download_no_sample_found(self):
+
self.snippet_call_download_failure('https://atcoder.jp/contests/tenka1-2013-quala/tasks/tenka1_2013_qualA_a')
+
self.snippet_call_download_failure('https://open.kattis.com/problems/hello')
+
++ @unittest.skip("Disabled by Guix")
+ def test_call_download_twice(self):
+
self.snippet_call_download_twice('https://atcoder.jp/contests/abc114/tasks/abc114_c',
'https://atcoder.jp/contests/abc003/tasks/abc003_4', [
+ {
+
+--- a/tests/command_test.py
++++ b/tests/command_test.py
+@@ -1319,7 +1319,7 @@ class TestTest(unittest.TestCase):
+ timer = threading.Timer(1.0, send_keyboard_interrupt)
+ timer.start()
+ result = tests.utils.run_in_sandbox(args=['-v', 'test', '-c',
tests.utils.python_c("import time; time.sleep(10) #
{}".format(marker_for_callee)), 'test/{}-1.in'.format(marker_for_caller)],
files=files)
+- self.assertNotEqual(result['proc'].returncode, 0)
++ # self.assertNotEqual(result['proc'].returncode, 0)
+
+ # check there are no processes whose command-line arguments contains
the marker word
+ for cmdline in pathlib.Path('/proc').glob('*/cmdline'):
diff --git a/gnu/packages/python-xyz.scm b/gnu/packages/python-xyz.scm
index a64a86492c..c95defd999 100644
--- a/gnu/packages/python-xyz.scm
+++ b/gnu/packages/python-xyz.scm
@@ -24630,6 +24630,41 @@ interface (@command{oj-api} command) which talks JSON
compatible with
jmerle/competitive-companion.")
(license license:expat)))
+(define-public online-judge-tools
+ (package
+ (name "online-judge-tools")
+ (version "11.5.1")
+ ;; Source distributions are not uploaded to PyPI.
+ ;; https://pypi.org/project/online-judge-tools/11.5.1/#files
+ (source (origin
+ (method git-fetch)
+ (uri (git-reference
+ (url "https://github.com/online-judge-tools/oj")
+ (commit (string-append "v" version))))
+ (file-name (git-file-name name version))
+ (sha256
+ (base32
+ "0zkzmmjgjb6lyrzq1ip54cpnp7al9a7mcyjyi5vx58bvnx3q0c6m"))
+ (patches (search-patches "online-judge-tools.patch"))))
+ (build-system python-build-system)
+ (arguments
+ (list #:phases #~(modify-phases %standard-phases
+ ;; These tests require network connections
+ (add-after 'unpack 'remove-failing-test
+ (lambda _
+ (delete-file "tests/command_version.py") #t)))))
+ (inputs (list time))
+ (propagated-inputs (list python-online-judge-api-client python-colorama
+ python-requests))
+ (home-page "https://github.com/online-judge-tools/oj")
+ (synopsis "Command to help solving problems on various online judges")
+ (description
+ "@command{oj} is a command line tool to help solving problems on
+various online judges. This command automates downloading sample
+cases, generating additional test cases, testing for your code, and
+submitting it.")
+ (license license:expat)))
+
(define-public python-parso
(package
(name "python-parso")
- branch master updated (5d79012073 -> 5746d043a6), guix-commits, 2023/10/30
- 02/13: gnu: Add ffmpeg-normalize., guix-commits, 2023/10/30
- 05/13: gnu: Add python-online-judge-api-client., guix-commits, 2023/10/30
- 04/13: gnu: Add aerich., guix-commits, 2023/10/30
- 03/13: gnu: Add python-ddlparse., guix-commits, 2023/10/30
- 01/13: gnu: Add ffmpeg-progress-yield., guix-commits, 2023/10/30
- 09/13: gnu: Remove python-resolvelib@0.5., guix-commits, 2023/10/30
- 06/13: gnu: Add online-judge-tools.,
guix-commits <=
- 07/13: gnu: Add r-consort., guix-commits, 2023/10/30
- 08/13: gnu: ansible-core: Update to 2.15.5 and fix tests., guix-commits, 2023/10/30
- 11/13: gnu: labwc: Update to 0.6.5., guix-commits, 2023/10/30
- 12/13: gnu: cockatrice: Update to 2.9.0., guix-commits, 2023/10/30
- 10/13: gnu: ansible: Update to 8.5.0., guix-commits, 2023/10/30
- 13/13: gnu: transmission: Update to 4.0.4., guix-commits, 2023/10/30