[tor-commits] [nyx/master] Initial cache table
atagar at torproject.org
atagar at torproject.org
Sun Sep 3 01:24:13 UTC 2017
commit de421f406db122400a9b17c676f4667e6be83a69
Author: Damian Johnson <atagar at torproject.org>
Date: Thu Aug 31 10:27:16 2017 -0700
Initial cache table
Our initial use for the cache is pretty clear so making a table for it and
adjusting our tests to use it.
---
nyx/__init__.py | 2 ++
test/cache.py | 27 +++++++++++++++++----------
2 files changed, 19 insertions(+), 10 deletions(-)
diff --git a/nyx/__init__.py b/nyx/__init__.py
index ee146a6..8c3d396 100644
--- a/nyx/__init__.py
+++ b/nyx/__init__.py
@@ -93,6 +93,8 @@ SCHEMA_VERSION = 1 # version of our scheme, bump this if you change the followi
SCHEMA = (
'CREATE TABLE schema(version NUMBER)',
'INSERT INTO schema(version) VALUES (%i)' % SCHEMA_VERSION,
+
+ 'CREATE TABLE relays(fingerprint TEXT PRIMARY KEY, address TEXT, or_port NUMBER, nickname TEXT)',
)
diff --git a/test/cache.py b/test/cache.py
index 1c30f40..01f99af 100644
--- a/test/cache.py
+++ b/test/cache.py
@@ -9,6 +9,11 @@ import nyx
from mock import Mock, patch
+FINGERPRINT = '3EA8E960F6B94CE30062AA8EF02894C00F8D1E66'
+ADDRESS = '208.113.165.162'
+PORT = 1443
+NICKNAME = 'caersidi'
+
class TestCache(unittest.TestCase):
def setUp(self):
@@ -16,26 +21,28 @@ class TestCache(unittest.TestCase):
@patch('nyx.data_directory', Mock(return_value = None))
def test_memory_cache(self):
+ """
+ Create a cache in memory.
+ """
+
with nyx.cache() as cache:
self.assertEqual((0, 'main', ''), cache.execute("PRAGMA database_list").fetchone())
-
- cache.execute('CREATE TABLE aliases(alias TEXT, command TEXT)')
- cache.execute('INSERT INTO aliases(alias, command) VALUES (?,?)', ('l', 'ls -xF --color=auto'))
- cache.execute('INSERT INTO aliases(alias, command) VALUES (?,?)', ('ll', 'ls -hlA --color=auto'))
- self.assertEqual('ls -hlA --color=auto', cache.execute('SELECT command FROM aliases WHERE alias=?', ('ll',)).fetchone()[0])
+ cache.execute('INSERT INTO relays(fingerprint, address, or_port, nickname) VALUES (?,?,?,?)', (FINGERPRINT, ADDRESS, PORT, NICKNAME))
+ self.assertEqual(NICKNAME, cache.execute('SELECT nickname FROM relays WHERE fingerprint=?', (FINGERPRINT,)).fetchone()[0])
def test_file_cache(self):
+ """
+ Create a new cache file, and ensure we can reload cached results.
+ """
+
with tempfile.NamedTemporaryFile(suffix = '.sqlite') as tmp:
with patch('nyx.data_directory', Mock(return_value = tmp.name)):
with nyx.cache() as cache:
self.assertEqual((0, 'main', tmp.name), cache.execute("PRAGMA database_list").fetchone())
-
- cache.execute('CREATE TABLE aliases(alias TEXT, command TEXT)')
- cache.execute('INSERT INTO aliases(alias, command) VALUES (?,?)', ('l', 'ls -xF --color=auto'))
- cache.execute('INSERT INTO aliases(alias, command) VALUES (?,?)', ('ll', 'ls -hlA --color=auto'))
+ cache.execute('INSERT INTO relays(fingerprint, address, or_port, nickname) VALUES (?,?,?,?)', (FINGERPRINT, ADDRESS, PORT, NICKNAME))
cache.commit()
nyx.CACHE = None
with nyx.cache() as cache:
- self.assertEqual('ls -hlA --color=auto', cache.execute('SELECT command FROM aliases WHERE alias=?', ('ll',)).fetchone()[0])
+ self.assertEqual(NICKNAME, cache.execute('SELECT nickname FROM relays WHERE fingerprint=?', (FINGERPRINT,)).fetchone()[0])
More information about the tor-commits
mailing list