add db.recent(mode, limit) method

This commit is contained in:
posativ 2012-10-24 20:09:22 +02:00
parent 2bfbad39ca
commit 05b77f99fe
2 changed files with 38 additions and 0 deletions

View File

@ -52,8 +52,21 @@ class Abstract:
@abc.abstractmethod @abc.abstractmethod
def retrieve(self, path, mode): def retrieve(self, path, mode):
"""
Return all comments for `path` with `mode`.
"""
return return
@abc.abstractmethod
def recent(self, mode=7, limit=None):
"""
Return most recent comments with `mode`. If `limit` is None, return
*all* comments that are currently stored, otherwise limit by `limit`.
"""
return
class SQLite(Abstract): class SQLite(Abstract):
"""A basic :class:`Abstract` implementation using SQLite3. All comments """A basic :class:`Abstract` implementation using SQLite3. All comments
@ -152,3 +165,18 @@ class SQLite(Abstract):
for item in rv: for item in rv:
yield self.query2comment(item) yield self.query2comment(item)
def recent(self, mode=7, limit=None):
sql = 'SELECT * FROM comments WHERE (? | mode) = ? ORDER BY created ASC'
args = [mode, mode]
if limit:
sql += ' LIMIT ?'
args.append(limit)
with sqlite3.connect(self.dbpath) as con:
rv = con.execute(sql + ';', args).fetchall()
for item in rv:
yield self.query2comment(item)

View File

@ -70,6 +70,16 @@ class TestSQLite(unittest.TestCase):
text='F**CK', author='P*NIS', website='http://somebadhost.org/')) text='F**CK', author='P*NIS', website='http://somebadhost.org/'))
assert self.db.delete('/', rv.id) == None assert self.db.delete('/', rv.id) == None
def test_recent(self):
self.db.add('/path/', comment(text='2'))
for x in range(5):
self.db.add('/', comment(text='%i' % (x+1)))
assert len(list(self.db.recent(mode=7))) == 6
assert len(list(self.db.recent(mode=7, limit=5))) == 5
def tearDown(self): def tearDown(self):
os.unlink(self.path) os.unlink(self.path)