aboutsummaryrefslogtreecommitdiffstats
path: root/library/python/svn_version
diff options
context:
space:
mode:
Diffstat (limited to 'library/python/svn_version')
-rw-r--r--library/python/svn_version/__init__.py2
-rw-r--r--library/python/svn_version/__svn_version.pyx4
-rw-r--r--library/python/svn_version/ut/test_simple.py10
3 files changed, 12 insertions, 4 deletions
diff --git a/library/python/svn_version/__init__.py b/library/python/svn_version/__init__.py
index 7ef7d6dac7..7eeb9573e8 100644
--- a/library/python/svn_version/__init__.py
+++ b/library/python/svn_version/__init__.py
@@ -1 +1 @@
-from .__svn_version import svn_version, commit_id, svn_revision, svn_last_revision, hash, svn_branch, svn_tag, patch_number # noqa
+from .__svn_version import svn_version, commit_id, svn_revision, svn_last_revision, hash, svn_branch, svn_tag, patch_number, vcs # noqa
diff --git a/library/python/svn_version/__svn_version.pyx b/library/python/svn_version/__svn_version.pyx
index d66bc09d24..95f74f525e 100644
--- a/library/python/svn_version/__svn_version.pyx
+++ b/library/python/svn_version/__svn_version.pyx
@@ -1,6 +1,7 @@
import future.utils as fu
cdef extern from "library/cpp/svnversion/svnversion.h":
+ cdef const char* GetVCS() except +;
cdef const char* GetProgramSvnVersion() except +;
cdef int GetProgramSvnRevision() except +;
cdef int GetArcadiaLastChangeNum() except +;
@@ -33,3 +34,6 @@ def svn_tag():
def patch_number():
return GetArcadiaPatchNumber()
+
+def vcs():
+ return fu.bytes_to_native_str(GetVCS())
diff --git a/library/python/svn_version/ut/test_simple.py b/library/python/svn_version/ut/test_simple.py
index 0eb94ccbbc..50fa78f55d 100644
--- a/library/python/svn_version/ut/test_simple.py
+++ b/library/python/svn_version/ut/test_simple.py
@@ -5,12 +5,16 @@ def test_simple():
assert sv.svn_version()
assert isinstance(sv.svn_version(), str)
- # svn_revision() will be equal to zero on non-trunk commits
- assert sv.svn_revision() >= 0
+ assert sv.vcs()
+ assert isinstance(sv.vcs(), str)
+
+ # svn_revision() will be -1 on non-trunk commits via arc
+ # svn revision of 0 technically may exist, but practiacally it will never appear here
+ assert sv.svn_revision() >= 0 or (sv.vcs() != "svn" and sv.svn_revision() == -1)
assert isinstance(sv.svn_revision(), int)
# svn_last_revision() will be equal to zero on non-trunk commits
- assert sv.svn_last_revision() >= 0
+ assert sv.svn_last_revision() >= 0 or (sv.vcs() != "svn" and sv.svn_last_revision() == -1)
assert isinstance(sv.svn_last_revision(), int)
assert sv.commit_id()