1
0

25 Commits

Author SHA256 Message Date
148b90ae0e Accepting request 1193580 from devel:languages:python
- Update to 2.2.0:
  * Exclude a list of paths from diff.
  * really drop python<=3.7 support
  * remove last bits of python2 support
  * Fix pypi release readme formatting
  * Minimal conversion to pytest+hypothesis
  * Added simple equality operator for class Symbol
  * jsondiff: fix symbol equality
  * setup.py: migrate to pyproject.toml
  * fix: better diffing of empty containers
  * add rightonly jsondiff syntax
  * Introduce YAML support
  * packaging: revert to requirements files
- Switch back to PyPi tarball. (required for setuptools_scm)
- Drop patch remove_nose.patch, no longer required.

OBS-URL: https://build.opensuse.org/request/show/1193580
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=11
2024-08-13 11:24:52 +00:00
f16308c50a Accepting request 1161732 from devel:languages:python
OBS-URL: https://build.opensuse.org/request/show/1161732
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=10
2024-03-26 18:28:09 +00:00
1bf636c0da Accepting request 1161729 from home:glaubitz:branches:devel:languages:python
- Switch build system from setuptools to pyproject.toml
  + Add python-pip and python-wheel to BuildRequires
  + Replace %python_build with %pyproject_wheel
  + Replace %python_install with %pyproject_install
- Limit Python files matched in %files section

OBS-URL: https://build.opensuse.org/request/show/1161729
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=22
2024-03-26 12:15:05 +00:00
30e7d01460 Accepting request 1093032 from devel:languages:python
OBS-URL: https://build.opensuse.org/request/show/1093032
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=9
2023-06-14 14:30:14 +00:00
ca233bebd3 Accepting request 1092866 from home:ecsos:python
- Add %{?sle15_python_module_pythons}

OBS-URL: https://build.opensuse.org/request/show/1092866
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=20
2023-06-14 06:24:56 +00:00
3cc17606ee Accepting request 978978 from devel:languages:python
- Update to version 2.0.0
  * Removed deprecated function
  * Remove deprecated jsondiff entry point
- from version 1.3.1
  * Optionally allow different escape_str than '$'
  * Clarified the readme, closes #23
  * Fixed readme
- Remove jsondiff command from %install, %post, %postun and %files sections (forwarded request 978966 from glaubitz)

OBS-URL: https://build.opensuse.org/request/show/978978
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=8
2022-05-24 18:33:35 +00:00
a37284164b Accepting request 978966 from home:glaubitz:branches:devel:languages:python
- Update to version 2.0.0
  * Removed deprecated function
  * Remove deprecated jsondiff entry point
- from version 1.3.1
  * Optionally allow different escape_str than '$'
  * Clarified the readme, closes #23
  * Fixed readme
- Remove jsondiff command from %install, %post, %postun and %files sections

OBS-URL: https://build.opensuse.org/request/show/978966
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=18
2022-05-24 13:35:17 +00:00
c52122e947 Accepting request 936286 from devel:languages:python
OBS-URL: https://build.opensuse.org/request/show/936286
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=7
2021-12-07 23:00:07 +00:00
0bcdfe2073 Accepting request 936188 from home:glaubitz:branches:devel:languages:python
- Update to version 1.3.0
  *  Update README.rst
  *  Add license to setup.py
  *  Upating travis config to explicitly set ubuntu versions to use
     for each python version.
  *  Fix long list diffing bug by converting recursive code to iterative.
  *  Add failing test for list-diff recursion error bug
- Refresh patches for new version
  * remove_nose.patch
- Switch Source field to point to Github tarball URL
  * The tarball from PyPi does not contain the tests

OBS-URL: https://build.opensuse.org/request/show/936188
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=17
2021-12-07 16:02:03 +00:00
0317419a6b Accepting request 834153 from devel:languages:python
- Add remove_nose.patch to remove requirement for nose.

OBS-URL: https://build.opensuse.org/request/show/834153
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=6
2020-09-14 10:30:42 +00:00
00a6eee6d7 - Add remove_nose.patch to remove requirement for nose.
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=15
2020-09-13 17:40:01 +00:00
f714c660f1 Accepting request 808778 from devel:languages:python
OBS-URL: https://build.opensuse.org/request/show/808778
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=5
2020-05-26 15:48:51 +00:00
Tomáš Chvátal
941e1918cc Accepting request 808768 from home:pgajdos:python
submit

OBS-URL: https://build.opensuse.org/request/show/808768
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=13
2020-05-25 13:31:32 +00:00
d142d3f67f Accepting request 735642 from devel:languages:python
OBS-URL: https://build.opensuse.org/request/show/735642
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=4
2019-10-08 17:57:12 +00:00
Tomáš Chvátal
e6964f481c Accepting request 735636 from home:mcalabkova:branches:devel:languages:python
- Update to version 1.2.0 (finally)
  * Deprecate the jsondiff command due to conflicts with json-patch

OBS-URL: https://build.opensuse.org/request/show/735636
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=11
2019-10-07 09:09:51 +00:00
1e08a1a4fa Accepting request 707064 from devel:languages:python
OBS-URL: https://build.opensuse.org/request/show/707064
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=3
2019-06-03 16:56:06 +00:00
Tomáš Chvátal
6f76e1868b Accepting request 706948 from home:jengelh:branches:devel:languages:python
- Use noun phrase in summary.

OBS-URL: https://build.opensuse.org/request/show/706948
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=9
2019-06-03 08:04:48 +00:00
695dbc807c Accepting request 703808 from devel:languages:python
OBS-URL: https://build.opensuse.org/request/show/703808
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=2
2019-05-22 13:39:39 +00:00
Tomáš Chvátal
8d2ca38c86 Accepting request 703806 from home:swulf:branches:devel:languages:python
Removing conflict with jsonpatch

OBS-URL: https://build.opensuse.org/request/show/703806
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=7
2019-05-17 22:01:38 +00:00
Tomáš Chvátal
25111f3ba9 Accepting request 703019 from home:gary_smith:branches:devel:languages:python
- Upgraded to 1.1.2
  * no changelog available

OBS-URL: https://build.opensuse.org/request/show/703019
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=6
2019-05-14 22:23:58 +00:00
72b088ab20 Accepting request 607074 from devel:languages:python
OBS-URL: https://build.opensuse.org/request/show/607074
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/python-jsondiff?expand=0&rev=1
2018-05-16 16:35:15 +00:00
Tomáš Chvátal
96ff2aeddb OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=4 2018-05-14 14:34:20 +00:00
Tomáš Chvátal
67c9310d3f - Conflict with python-jsonpatch
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=3
2018-05-14 11:25:44 +00:00
Todd R
91d50c4cad Accepting request 605506 from home:TheBlackCat:branches:devel:languages:python
- Fix typo to allow building

OBS-URL: https://build.opensuse.org/request/show/605506
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=2
2018-05-09 01:00:54 +00:00
Tomáš Chvátal
ff1dca57cb - Initial commit, required by python-moto
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-jsondiff?expand=0&rev=1
2018-05-08 18:51:56 +00:00
2 changed files with 0 additions and 303 deletions

View File

@@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:5cf3dfb212dcdc6ee104f40e30824a2f3ddaa05938d111ce0eea6646518b8339
size 15405

View File

@@ -1,300 +0,0 @@
diff -Nru jsondiff-1.3.0.orig/tests/__init__.py jsondiff-1.3.0/tests/__init__.py
--- jsondiff-1.3.0.orig/tests/__init__.py 2021-04-19 21:51:14.000000000 +0200
+++ jsondiff-1.3.0/tests/__init__.py 2021-12-07 10:25:30.252455974 +0100
@@ -1,130 +1,15 @@
import sys
-import unittest
-from jsondiff import diff, replace, add, discard, insert, delete, update, JsonDiffer
-
-from .utils import generate_random_json, perturbate_json
-
-from nose_random import randomize
-
-
-class JsonDiffTests(unittest.TestCase):
-
- def test_a(self):
-
- self.assertEqual({}, diff(1, 1))
- self.assertEqual({}, diff(True, True))
- self.assertEqual({}, diff('abc', 'abc'))
- self.assertEqual({}, diff([1, 2], [1, 2]))
- self.assertEqual({}, diff((1, 2), (1, 2)))
- self.assertEqual({}, diff({1, 2}, {1, 2}))
- self.assertEqual({}, diff({'a': 1, 'b': 2}, {'a': 1, 'b': 2}))
- self.assertEqual({}, diff([], []))
- self.assertEqual({}, diff(None, None))
- self.assertEqual({}, diff({}, {}))
- self.assertEqual({}, diff(set(), set()))
-
- self.assertEqual(2, diff(1, 2))
- self.assertEqual(False, diff(True, False))
- self.assertEqual('def', diff('abc', 'def'))
- self.assertEqual([3, 4], diff([1, 2], [3, 4]))
- self.assertEqual((3, 4), diff((1, 2), (3, 4)))
- self.assertEqual({3, 4}, diff({1, 2}, {3, 4}))
- self.assertEqual({replace: {'c': 3, 'd': 4}}, diff({'a': 1, 'b': 2}, {'c': 3, 'd': 4}))
-
- self.assertEqual({replace: {'c': 3, 'd': 4}}, diff([1, 2], {'c': 3, 'd': 4}))
- self.assertEqual(123, diff({'a': 1, 'b': 2}, 123))
-
- self.assertEqual({delete: ['b']}, diff({'a': 1, 'b': 2}, {'a': 1}))
- self.assertEqual({'b': 3}, diff({'a': 1, 'b': 2}, {'a': 1, 'b': 3}))
- self.assertEqual({'c': 3}, diff({'a': 1, 'b': 2}, {'a': 1, 'b': 2, 'c': 3}))
- self.assertEqual({delete: ['b'], 'c': 3}, diff({'a': 1, 'b': 2}, {'a': 1, 'c': 3}))
-
- self.assertEqual({add: {3}}, diff({1, 2}, {1, 2, 3}))
- self.assertEqual({add: {3}, discard: {4}}, diff({1, 2, 4}, {1, 2, 3}))
- self.assertEqual({discard: {4}}, diff({1, 2, 4}, {1, 2}))
-
- self.assertEqual({insert: [(1, 'b')]}, diff(['a', 'c'], ['a', 'b', 'c']))
- self.assertEqual({insert: [(1, 'b')], delete: [3, 0]}, diff(['x', 'a', 'c', 'x'], ['a', 'b', 'c']))
- self.assertEqual(
- {insert: [(2, 'b')], delete: [4, 0], 1: {'v': 20}},
- diff(['x', 'a', {'v': 11}, 'c', 'x'], ['a', {'v': 20}, 'b', 'c'])
- )
- self.assertEqual(
- {insert: [(2, 'b')], delete: [4, 0], 1: {'v': 20}},
- diff(['x', 'a', {'u': 10, 'v': 11}, 'c', 'x'], ['a', {'u': 10, 'v': 20}, 'b', 'c'])
- )
-
- def test_marshal(self):
- differ = JsonDiffer()
-
- d = {
- delete: 3,
- '$delete': 4,
- insert: 4,
- '$$something': 1
- }
-
- dm = differ.marshal(d)
-
- self.assertEqual(d, differ.unmarshal(dm))
-
- def generate_scenario(self, rng):
- a = generate_random_json(rng, sets=True)
- b = perturbate_json(a, rng, sets=True)
- return a, b
-
- def generate_scenario_no_sets(self, rng):
- a = generate_random_json(rng, sets=False)
- b = perturbate_json(a, rng, sets=False)
- return a, b
-
- @randomize(1000, generate_scenario_no_sets)
- def test_dump(self, scenario):
- a, b = scenario
- diff(a, b, syntax='compact', dump=True)
- diff(a, b, syntax='explicit', dump=True)
- diff(a, b, syntax='symmetric', dump=True)
-
- @randomize(1000, generate_scenario)
- def test_compact_syntax(self, scenario):
- a, b = scenario
- differ = JsonDiffer(syntax='compact')
- d = differ.diff(a, b)
- self.assertEqual(b, differ.patch(a, d))
- dm = differ.marshal(d)
- self.assertEqual(d, differ.unmarshal(dm))
-
-
- @randomize(1000, generate_scenario)
- def test_explicit_syntax(self, scenario):
- a, b = scenario
- differ = JsonDiffer(syntax='explicit')
- d = differ.diff(a, b)
- # self.assertEqual(b, differ.patch(a, d))
- dm = differ.marshal(d)
- self.assertEqual(d, differ.unmarshal(dm))
-
- @randomize(1000, generate_scenario)
- def test_symmetric_syntax(self, scenario):
- a, b = scenario
- differ = JsonDiffer(syntax='symmetric')
- d = differ.diff(a, b)
- self.assertEqual(b, differ.patch(a, d))
- self.assertEqual(a, differ.unpatch(b, d))
- dm = differ.marshal(d)
- self.assertEqual(d, differ.unmarshal(dm))
-
- def test_long_arrays(self):
- size = 100
- a = [{'a': i, 'b': 2 * i} for i in range(1, size)]
- b = [{'a': i, 'b': 3 * i} for i in range(1, size)]
- r = sys.getrecursionlimit()
- sys.setrecursionlimit(size - 1)
-
- try:
- diff(a, b)
- except RecursionError:
- self.fail('cannot diff long arrays')
- finally:
- sys.setrecursionlimit(r)
+def test_long_arrays(self):
+ size = 100
+ a = [{'a': i, 'b': 2 * i} for i in range(1, size)]
+ b = [{'a': i, 'b': 3 * i} for i in range(1, size)]
+ r = sys.getrecursionlimit()
+ sys.setrecursionlimit(size - 1)
+
+ try:
+ diff(a, b)
+ except RecursionError:
+ self.fail('cannot diff long arrays')
+ finally:
+ sys.setrecursionlimit(r)
diff -Nru jsondiff-1.3.0.orig/tests/_random.py jsondiff-1.3.0/tests/_random.py
--- jsondiff-1.3.0.orig/tests/_random.py 1970-01-01 01:00:00.000000000 +0100
+++ jsondiff-1.3.0/tests/_random.py 2021-12-07 10:21:59.457195559 +0100
@@ -0,0 +1,33 @@
+import sys
+from random import Random
+
+PY3 = (sys.version_info[0] == 3)
+
+
+def _generate_tag(n, rng):
+ return ''.join(rng.choice('ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789')
+ for _ in range(n))
+
+
+def randomize(n, scenario_generator, seed=12038728732):
+ def decorator(test):
+ def randomized_test(self):
+ rng_seed = Random(seed)
+ nseeds = n
+ # (rng_seed.getrandbits(32) for i in range(n))
+ seeds = (_generate_tag(12, rng_seed) for i in range(n))
+ for i, rseed in enumerate(seeds):
+ rng = Random(rseed)
+ scenario = scenario_generator(self, rng)
+ try:
+ test(self, scenario)
+ except Exception as e:
+ import sys
+ if PY3:
+ raise type(e).with_traceback(type(e)('%s with scenario %s (%i of %i)' %
+ (e.message, rseed, i+1, nseeds)), sys.exc_info()[2])
+ else:
+ raise (type(e), type(e)('%s with scenario %s (%i of %i)'
+ % (e.message, rseed, i+1, nseeds)), sys.exc_info()[2])
+ return randomized_test
+ return decorator
diff -Nru jsondiff-1.3.0.orig/tests/test_jsondiff.py jsondiff-1.3.0/tests/test_jsondiff.py
--- jsondiff-1.3.0.orig/tests/test_jsondiff.py 1970-01-01 01:00:00.000000000 +0100
+++ jsondiff-1.3.0/tests/test_jsondiff.py 2021-12-07 10:21:59.457195559 +0100
@@ -0,0 +1,112 @@
+import unittest
+
+from jsondiff import diff, replace, add, discard, insert, delete, update, JsonDiffer
+from tests.utils import generate_random_json, perturbate_json
+from tests._random import randomize
+
+
+class JsonDiffTests(unittest.TestCase):
+
+ def test_a(self):
+
+ self.assertEqual({}, diff(1, 1))
+ self.assertEqual({}, diff(True, True))
+ self.assertEqual({}, diff('abc', 'abc'))
+ self.assertEqual({}, diff([1, 2], [1, 2]))
+ self.assertEqual({}, diff((1, 2), (1, 2)))
+ self.assertEqual({}, diff({1, 2}, {1, 2}))
+ self.assertEqual({}, diff({'a': 1, 'b': 2}, {'a': 1, 'b': 2}))
+ self.assertEqual({}, diff([], []))
+ self.assertEqual({}, diff(None, None))
+ self.assertEqual({}, diff({}, {}))
+ self.assertEqual({}, diff(set(), set()))
+
+ self.assertEqual(2, diff(1, 2))
+ self.assertEqual(False, diff(True, False))
+ self.assertEqual('def', diff('abc', 'def'))
+ self.assertEqual([3, 4], diff([1, 2], [3, 4]))
+ self.assertEqual((3, 4), diff((1, 2), (3, 4)))
+ self.assertEqual({3, 4}, diff({1, 2}, {3, 4}))
+ self.assertEqual({replace: {'c': 3, 'd': 4}}, diff({'a': 1, 'b': 2}, {'c': 3, 'd': 4}))
+
+ self.assertEqual({replace: {'c': 3, 'd': 4}}, diff([1, 2], {'c': 3, 'd': 4}))
+ self.assertEqual(123, diff({'a': 1, 'b': 2}, 123))
+
+ self.assertEqual({delete: ['b']}, diff({'a': 1, 'b': 2}, {'a': 1}))
+ self.assertEqual({'b': 3}, diff({'a': 1, 'b': 2}, {'a': 1, 'b': 3}))
+ self.assertEqual({'c': 3}, diff({'a': 1, 'b': 2}, {'a': 1, 'b': 2, 'c': 3}))
+ self.assertEqual({delete: ['b'], 'c': 3}, diff({'a': 1, 'b': 2}, {'a': 1, 'c': 3}))
+
+ self.assertEqual({add: {3}}, diff({1, 2}, {1, 2, 3}))
+ self.assertEqual({add: {3}, discard: {4}}, diff({1, 2, 4}, {1, 2, 3}))
+ self.assertEqual({discard: {4}}, diff({1, 2, 4}, {1, 2}))
+
+ self.assertEqual({insert: [(1, 'b')]}, diff(['a', 'c'], ['a', 'b', 'c']))
+ self.assertEqual({insert: [(1, 'b')], delete: [3, 0]}, diff(['x', 'a', 'c', 'x'], ['a', 'b', 'c']))
+ self.assertEqual(
+ {insert: [(2, 'b')], delete: [4, 0], 1: {'v': 20}},
+ diff(['x', 'a', {'v': 11}, 'c', 'x'], ['a', {'v': 20}, 'b', 'c'])
+ )
+ self.assertEqual(
+ {insert: [(2, 'b')], delete: [4, 0], 1: {'v': 20}},
+ diff(['x', 'a', {'u': 10, 'v': 11}, 'c', 'x'], ['a', {'u': 10, 'v': 20}, 'b', 'c'])
+ )
+
+ def test_marshal(self):
+ differ = JsonDiffer()
+
+ d = {
+ delete: 3,
+ '$delete': 4,
+ insert: 4,
+ '$$something': 1
+ }
+
+ dm = differ.marshal(d)
+
+ self.assertEqual(d, differ.unmarshal(dm))
+
+ def generate_scenario(self, rng):
+ a = generate_random_json(rng, sets=True)
+ b = perturbate_json(a, rng, sets=True)
+ return a, b
+
+ def generate_scenario_no_sets(self, rng):
+ a = generate_random_json(rng, sets=False)
+ b = perturbate_json(a, rng, sets=False)
+ return a, b
+
+ @randomize(1000, generate_scenario_no_sets)
+ def test_dump(self, scenario):
+ a, b = scenario
+ diff(a, b, syntax='compact', dump=True)
+ diff(a, b, syntax='explicit', dump=True)
+ diff(a, b, syntax='symmetric', dump=True)
+
+ @randomize(1000, generate_scenario)
+ def test_compact_syntax(self, scenario):
+ a, b = scenario
+ differ = JsonDiffer(syntax='compact')
+ d = differ.diff(a, b)
+ self.assertEqual(b, differ.patch(a, d))
+ dm = differ.marshal(d)
+ self.assertEqual(d, differ.unmarshal(dm))
+
+ @randomize(1000, generate_scenario)
+ def test_explicit_syntax(self, scenario):
+ a, b = scenario
+ differ = JsonDiffer(syntax='explicit')
+ d = differ.diff(a, b)
+ # self.assertEqual(b, differ.patch(a, d))
+ dm = differ.marshal(d)
+ self.assertEqual(d, differ.unmarshal(dm))
+
+ @randomize(1000, generate_scenario)
+ def test_symmetric_syntax(self, scenario):
+ a, b = scenario
+ differ = JsonDiffer(syntax='symmetric')
+ d = differ.diff(a, b)
+ self.assertEqual(b, differ.patch(a, d))
+ self.assertEqual(a, differ.unpatch(b, d))
+ dm = differ.marshal(d)
+ self.assertEqual(d, differ.unmarshal(dm))