From 8ddf6db84c552daf8776c2443cd092a66055b25f Mon Sep 17 00:00:00 2001 From: Natanael Arndt Date: Fri, 7 May 2021 19:36:48 +0200 Subject: [PATCH] Draft some test for atomic graphs --- tests/test_app.py | 76 +++++++++++++++++++++++++++++++++++++++-------- 1 file changed, 64 insertions(+), 12 deletions(-) diff --git a/tests/test_app.py b/tests/test_app.py index 6b88c23d..6beaad6b 100644 --- a/tests/test_app.py +++ b/tests/test_app.py @@ -2435,16 +2435,57 @@ def testThreeWayMerge(self): # execute INSERT DATA query update = "INSERT DATA {graph { .}}" - app.post('/sparql', data={"query": update}) + app.post('/sparql', data={"update": update}) app = create_app(args).test_client() # start new app to syncAll() update = "INSERT DATA {graph { .}}" - app.post('/sparql/develop?ref=develop', data={"query": update}) + app.post('/sparql/develop?ref=develop', data={"update": update}) app.post("/merge", data={"target": "master", "branch": "develop", "method": "three-way"}) + + def testContextMergeWithAtomicGraphs(self): + """Test merging two commits.""" + + # Prepate a git Repository + content = """ + . + """ + with TemporaryRepositoryFactory().withGraph("http://example.org/", content) as repo: + + # Start Quit + args = quitApp.getDefaults() + args['targetdir'] = repo.workdir + + #test_client + testApp = create_app(args) + testApp.testing = True + testApp.config["TESTING"] = True + with testApp.test_client() as app: + response = app.post("/branch", data={"oldbranch": "master", "newbranch": "develop"}) + self.assertEqual(int(response.status_code/100), 2) + + # execute INSERT DATA query + update = "INSERT DATA {graph { [ ] .}}" + response = app.post('/sparql', data={"update": update}) + self.assertEqual(int(response.status_code/100), 2) + + app = create_app(args).test_client() + # start new app to syncAll() + + update = "INSERT DATA {graph { .}}" + response = app.post('/sparql/develop?ref=develop', data={"update": update}) + self.assertEqual(int(response.status_code/100), 2) + + response = app.post("/merge", data={"target": "master", "branch": "develop", "method": "context"}) + # merge should fail + #print(response.text)# + print(response.json) + + self.assertEqual(response.status_code, 409) + def testContextMerge(self): """Test merging two commits.""" @@ -2455,21 +2496,32 @@ def testContextMerge(self): # Start Quit args = quitApp.getDefaults() args['targetdir'] = repo.workdir - app = create_app(args).test_client() - app.post("/branch", data={"oldbranch": "master", "newbranch": "develop"}) + #test_client + testApp = create_app(args) + testApp.testing = True + testApp.config["TESTING"] = True + with testApp.test_client() as app: + response = app.post("/branch", data={"oldbranch": "master", "newbranch": "develop"}) + self.assertEqual(int(response.status_code/100), 2) - # execute INSERT DATA query - update = "INSERT DATA {graph { .}}" - app.post('/sparql', data={"query": update}) + # execute INSERT DATA query + update = "INSERT DATA {graph { .}}" + response = app.post('/sparql', data={"update": update}) + self.assertEqual(int(response.status_code/100), 2) - app = create_app(args).test_client() - # start new app to syncAll() + app = create_app(args).test_client() + # start new app to syncAll() - update = "INSERT DATA {graph { .}}" - app.post('/sparql/develop?ref=develop', data={"query": update}) + update = "INSERT DATA {graph { .}}" + request = app.post('/sparql/develop?ref=develop', data={"update": update}) + self.assertEqual(int(request.status_code/100), 2) - app.post("/merge", data={"target": "master", "branch": "develop", "method": "context"}) + response = app.post("/merge", data={"target": "master", "branch": "develop", "method": "context"}) + # merge sh + print(response.json) + print(response.status_code) + self.assertEqual(response.status_code, 409) def testPull(self): """Test /pull API request."""