From ef78c7cd1e3441dbe52b896750b3ec5e9539a161 Mon Sep 17 00:00:00 2001 From: Paul Date: Tue, 30 Aug 2016 11:40:20 -0500 Subject: [PATCH 1/4] adding subTest for distiguishing between iterations --- tests/test_bukuDb.py | 53 ++++++++++++++++++++++++++------------------ 1 file changed, 32 insertions(+), 21 deletions(-) diff --git a/tests/test_bukuDb.py b/tests/test_bukuDb.py index a6c06ae..196fe9a 100644 --- a/tests/test_bukuDb.py +++ b/tests/test_bukuDb.py @@ -39,6 +39,8 @@ TEST_BOOKMARKS = [ ['http://slashdot.org', ], ] +inclusive_range = lambda start, end: range(start, end + 1) + @pytest.fixture() def setup(): os.environ['XDG_DATA_HOME'] = TEST_TEMP_DIR_PATH @@ -144,7 +146,8 @@ class TestBukuDb(unittest.TestCase): self.assertIsNotNone(from_db) # comparing data for pair in zip(from_db[1:], bookmark): - self.assertEqual(*pair) + with self.subTest(from_db=from_db[1:], bookmark=bookmark): + self.assertEqual(*pair) # TODO: tags should be passed to the api as a sequence... @@ -161,9 +164,11 @@ class TestBukuDb(unittest.TestCase): # retrieving bookmark from database from_db = self.bdb.get_bookmark_by_index(index) self.assertIsNotNone(from_db) + # checking if values are updated for pair in zip(from_db[1:], new_values): - self.assertEqual(*pair) + with self.subTest(from_db=from_db[1:], new_values=new_values): + self.assertEqual(*pair) # @unittest.skip('skipping') def test_append_tag_at_index(self): @@ -171,23 +176,27 @@ class TestBukuDb(unittest.TestCase): self.bdb.add_bookmark(*bookmark) # tags to add - old_tags = self.bdb.get_bookmark_by_index(1)[3] new_tags = ",foo,bar,baz" - self.bdb.append_tag_at_index(1, new_tags) - # updated list of tags - from_db = self.bdb.get_bookmark_by_index(1)[3] - # checking if new tags were added to the bookmark - self.assertTrue(all( x in from_db.split(',') for x in new_tags.split(',') )) - # checking if old tags still exist - self.assertTrue(all( x in from_db.split(',') for x in old_tags.split(',') )) + for idx, bookmark in enumerate(self.bookmarks): + bm_index = idx + 1 + old_tags = self.bdb.get_bookmark_by_index(bm_index)[3] + # adding tags to existing + self.bdb.append_tag_at_index(bm_index, new_tags) + # get updated set of tags + from_db = self.bdb.get_bookmark_by_index(bm_index)[3] + + with self.subTest(old_tags=old_tags, updated_tags=from_db): + # checking if new tags were added to the bookmark + self.assertTrue(all( x in from_db.split(',') for x in new_tags.split(',') )) + # checking if old tags still exist + self.assertTrue(all( x in from_db.split(',') for x in old_tags.split(',') )) # @unittest.skip('skipping') def test_append_tag_at_all_indices(self): for bookmark in self.bookmarks: self.bdb.add_bookmark(*bookmark) - inclusive_range = lambda start, end: range(start, end + 1) # tags to add new_tags = ",foo,bar,baz" # record of original tags for each bookmark @@ -198,10 +207,11 @@ class TestBukuDb(unittest.TestCase): # updated tags for each bookmark from_db = [ (i, self.bdb.get_bookmark_by_index(i)[3]) for i in inclusive_range(1, len(self.bookmarks)) ] for index, tagset in from_db: - # checking if new tags added to bookmark - self.assertTrue(all( x in tagset.split(',') for x in new_tags.split(',') )) - # checking if old tags still exist for boomark - self.assertTrue(all( x in tagset.split(',') for x in old_tagsets[index].split(',') )) + with self.subTest(): + # checking if new tags added to bookmark + self.assertTrue(all( x in tagset.split(',') for x in new_tags.split(',') )) + # checking if old tags still exist for boomark + self.assertTrue(all( x in tagset.split(',') for x in old_tagsets[index].split(',') )) # @unittest.skip('skipping') @@ -210,17 +220,18 @@ class TestBukuDb(unittest.TestCase): for bookmark in self.bookmarks: self.bdb.add_bookmark(*bookmark) - inclusive_range = lambda start, end: range(start, end + 1) # dictionary of db bookmark index: tags - tags_by_index = { i: self.bdb.get_bookmark_by_index(i)[3] for i in inclusive_range(1, len(self.bookmarks)) } + tagsets = [ self.bdb.get_bookmark_by_index(i)[3] for i in inclusive_range(1, len(self.bookmarks)) ] - for i, tags in tags_by_index.items(): + for i, tags in enumerate(tagsets): + idx = i + 1 # get the first tag from the bookmark to_delete = re.match(',.*?,', tags).group(0) - self.bdb.delete_tag_at_index(i, to_delete) + self.bdb.delete_tag_at_index(idx, to_delete) # get updated tags from db - from_db = self.bdb.get_bookmark_by_index(i)[3] - self.assertNotIn(to_delete, from_db) + from_db = self.bdb.get_bookmark_by_index(idx)[3] + with self.subTest(to_delete=to_delete, updated_tags=from_db): + self.assertNotIn(to_delete, from_db) # @unittest.skip('skipping') def test_refreshdb(self): From cfb2abfbc573520c98669f200dba21c408bf9fc1 Mon Sep 17 00:00:00 2001 From: Paul Date: Wed, 31 Aug 2016 19:50:31 -0500 Subject: [PATCH 2/4] moved select_tag_from_bookmarks back to append_tag --- buku | 23 ++++++++--------------- 1 file changed, 8 insertions(+), 15 deletions(-) diff --git a/buku b/buku index 79d6976..0cb77f2 100755 --- a/buku +++ b/buku @@ -446,21 +446,6 @@ class BukuDb: :tag_manual: string of comma-separated tags to add manually """ - self.select_tags_from_bookmarks(index) - resultset = self.cur.fetchall() - for row in resultset: - tags = '%s%s' % (row[1], tag_manual[1:]) - tags = parse_tags([tags]) - self.cur.execute('UPDATE bookmarks SET tags = ? WHERE id = ?', (tags, row[0],)) - - self.conn.commit() - - def select_tags_from_bookmarks(self, index): - """ Select either the tags for one bookmark or all bookmarks - - :param index: int position of record, 0 for all - """ - if index == 0: resp = input('Tags will be appended for ALL bookmarks. Enter \x1b[1my\x1b[21m to confirm: ') if resp != 'y': @@ -470,6 +455,14 @@ class BukuDb: else: self.cur.execute('SELECT id, tags FROM bookmarks WHERE id = ?', (index,)) + resultset = self.cur.fetchall() + for row in resultset: + tags = '%s%s' % (row[1], tag_manual[1:]) + tags = parse_tags([tags]) + self.cur.execute('UPDATE bookmarks SET tags = ? WHERE id = ?', (tags, row[0],)) + + self.conn.commit() + def delete_tag_at_index(self, index, tag_manual): """ Delete tags for bookmark at index From 1644a9f63f9e4c8834e3e380945eac1690e7d33b Mon Sep 17 00:00:00 2001 From: Paul Date: Wed, 31 Aug 2016 23:22:28 -0500 Subject: [PATCH 3/4] improved test_delete_all_bookmarks --- tests/test_bukuDb.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/tests/test_bukuDb.py b/tests/test_bukuDb.py index 196fe9a..1c81189 100644 --- a/tests/test_bukuDb.py +++ b/tests/test_bukuDb.py @@ -276,9 +276,12 @@ class TestBukuDb(unittest.TestCase): # deleting all bookmarks self.bdb.delete_all_bookmarks() # assert table has been dropped - with self.assertRaises(sqlite3.OperationalError): + with self.assertRaises(sqlite3.OperationalError) as ctx_man: self.bdb.get_bookmark_by_index(0) + err_msg = str(ctx_man.exception) + self.assertEqual(err_msg, 'no such table: bookmarks') + # @unittest.skip('skipping') def test_replace_tag(self): indices = [] From f865d6add95340bfa5bb4086e589d6b08ad14091 Mon Sep 17 00:00:00 2001 From: Paul Date: Sat, 3 Sep 2016 22:14:56 -0500 Subject: [PATCH 4/4] Revert "adding subTest for distiguishing between iterations" This reverts commit ef78c7cd1e3441dbe52b896750b3ec5e9539a161. --- tests/test_bukuDb.py | 53 ++++++++++++++++++-------------------------- 1 file changed, 21 insertions(+), 32 deletions(-) diff --git a/tests/test_bukuDb.py b/tests/test_bukuDb.py index 1c81189..6191bc1 100644 --- a/tests/test_bukuDb.py +++ b/tests/test_bukuDb.py @@ -39,8 +39,6 @@ TEST_BOOKMARKS = [ ['http://slashdot.org', ], ] -inclusive_range = lambda start, end: range(start, end + 1) - @pytest.fixture() def setup(): os.environ['XDG_DATA_HOME'] = TEST_TEMP_DIR_PATH @@ -146,8 +144,7 @@ class TestBukuDb(unittest.TestCase): self.assertIsNotNone(from_db) # comparing data for pair in zip(from_db[1:], bookmark): - with self.subTest(from_db=from_db[1:], bookmark=bookmark): - self.assertEqual(*pair) + self.assertEqual(*pair) # TODO: tags should be passed to the api as a sequence... @@ -164,11 +161,9 @@ class TestBukuDb(unittest.TestCase): # retrieving bookmark from database from_db = self.bdb.get_bookmark_by_index(index) self.assertIsNotNone(from_db) - # checking if values are updated for pair in zip(from_db[1:], new_values): - with self.subTest(from_db=from_db[1:], new_values=new_values): - self.assertEqual(*pair) + self.assertEqual(*pair) # @unittest.skip('skipping') def test_append_tag_at_index(self): @@ -176,27 +171,23 @@ class TestBukuDb(unittest.TestCase): self.bdb.add_bookmark(*bookmark) # tags to add + old_tags = self.bdb.get_bookmark_by_index(1)[3] new_tags = ",foo,bar,baz" + self.bdb.append_tag_at_index(1, new_tags) + # updated list of tags + from_db = self.bdb.get_bookmark_by_index(1)[3] - for idx, bookmark in enumerate(self.bookmarks): - bm_index = idx + 1 - old_tags = self.bdb.get_bookmark_by_index(bm_index)[3] - # adding tags to existing - self.bdb.append_tag_at_index(bm_index, new_tags) - # get updated set of tags - from_db = self.bdb.get_bookmark_by_index(bm_index)[3] - - with self.subTest(old_tags=old_tags, updated_tags=from_db): - # checking if new tags were added to the bookmark - self.assertTrue(all( x in from_db.split(',') for x in new_tags.split(',') )) - # checking if old tags still exist - self.assertTrue(all( x in from_db.split(',') for x in old_tags.split(',') )) + # checking if new tags were added to the bookmark + self.assertTrue(all( x in from_db.split(',') for x in new_tags.split(',') )) + # checking if old tags still exist + self.assertTrue(all( x in from_db.split(',') for x in old_tags.split(',') )) # @unittest.skip('skipping') def test_append_tag_at_all_indices(self): for bookmark in self.bookmarks: self.bdb.add_bookmark(*bookmark) + inclusive_range = lambda start, end: range(start, end + 1) # tags to add new_tags = ",foo,bar,baz" # record of original tags for each bookmark @@ -207,11 +198,10 @@ class TestBukuDb(unittest.TestCase): # updated tags for each bookmark from_db = [ (i, self.bdb.get_bookmark_by_index(i)[3]) for i in inclusive_range(1, len(self.bookmarks)) ] for index, tagset in from_db: - with self.subTest(): - # checking if new tags added to bookmark - self.assertTrue(all( x in tagset.split(',') for x in new_tags.split(',') )) - # checking if old tags still exist for boomark - self.assertTrue(all( x in tagset.split(',') for x in old_tagsets[index].split(',') )) + # checking if new tags added to bookmark + self.assertTrue(all( x in tagset.split(',') for x in new_tags.split(',') )) + # checking if old tags still exist for boomark + self.assertTrue(all( x in tagset.split(',') for x in old_tagsets[index].split(',') )) # @unittest.skip('skipping') @@ -220,18 +210,17 @@ class TestBukuDb(unittest.TestCase): for bookmark in self.bookmarks: self.bdb.add_bookmark(*bookmark) + inclusive_range = lambda start, end: range(start, end + 1) # dictionary of db bookmark index: tags - tagsets = [ self.bdb.get_bookmark_by_index(i)[3] for i in inclusive_range(1, len(self.bookmarks)) ] + tags_by_index = { i: self.bdb.get_bookmark_by_index(i)[3] for i in inclusive_range(1, len(self.bookmarks)) } - for i, tags in enumerate(tagsets): - idx = i + 1 + for i, tags in tags_by_index.items(): # get the first tag from the bookmark to_delete = re.match(',.*?,', tags).group(0) - self.bdb.delete_tag_at_index(idx, to_delete) + self.bdb.delete_tag_at_index(i, to_delete) # get updated tags from db - from_db = self.bdb.get_bookmark_by_index(idx)[3] - with self.subTest(to_delete=to_delete, updated_tags=from_db): - self.assertNotIn(to_delete, from_db) + from_db = self.bdb.get_bookmark_by_index(i)[3] + self.assertNotIn(to_delete, from_db) # @unittest.skip('skipping') def test_refreshdb(self):