Exemple #1
0
def test_select_basic_operations():
    db = DictDB(schema, 'pk')

    db.insert_ts(1, ats1)

    db.insert_ts(2, ats2)
    db.insert_ts(3, ats3)

    ids1, fields1 = db.select({'pk': {'==': 1}}, None, None)
    assert (ids1 == [1])

    ids2, fields2 = db.select({'pk': {'>': 1}}, None, None)
    assert (ids2 == [2, 3])

    ids3, fields3 = db.select({'pk': {'<': 2}}, None, None)
    assert (ids3 == [1])

    ids4, fields4 = db.select({'pk': {'!=': 1}}, None, None)
    assert (ids4 == [2, 3])

    ids5, fields5 = db.select({'pk': {'<=': 2}}, None, None)
    assert (ids5 == [1, 2])

    ids6, fields6 = db.select({'pk': {'>=': 2}}, None, None)
    assert (ids6 == [2, 3])

    ids7, fields7 = db.select({'pk': {'>': 1, '<': 3}}, None, None)
    assert (ids7 == [2])
Exemple #2
0
def main():
    # we augment the schema by adding columns for 5 vantage points
    for i in range(NUMVPS):
        schema["d_vp-{}".format(i)] = {'convert': float, 'index': 1}
    db = DictDB(schema, 'pk')
    server = TSDBServer(db)
    server.run()
Exemple #3
0
def test_delete():
    db = DictDB(schema, 'pk')

    # Upserting
    db.upsert_meta(1, {'ts': ats1, 'blarg': 3, 'order': 1})
    db.upsert_meta(2, {'ts': ats1, 'order': 1})
    db.upsert_meta(3, {'ts': ats1, 'not_there': 3, 'order': 3})
    db.upsert_meta(4, {'ts': ats1, 'blarg': 3})

    # Deleting
    db.delete_ts(1)
    db.delete_ts(2)
    db.delete_ts(3)

    # Tests
    rows = db.rows
    assert (len(rows) == 1)
    assert (4 in rows)
    assert (1 not in rows)
    assert (db.indexes['order'] == {})
    assert (db.indexes['blarg'] == {3: {4}})

    # Check to ensure that PKs that have been deleted are no
    # longer in the index
    assert (db.indexes['pk'] == {4: {4}})
    def setUp(self):
        identity = lambda x: x
        to_int = lambda x: int(x)
        to_float = lambda x: float(x)
        to_bool = lambda x: bool(x)

        schema = {
            'pk': {
                'convert': identity,
                'index': None
            },  #will be indexed anyways
            'ts': {
                'convert': identity,
                'index': None
            },
            'order': {
                'convert': to_int,
                'index': 1
            },
            'blarg': {
                'convert': to_int,
                'index': 1
            },
            'useless': {
                'convert': identity,
                'index': None
            },
            'mean': {
                'convert': to_float,
                'index': 1
            },
            'std': {
                'convert': to_float,
                'index': 1
            },
            'vp': {
                'convert': to_bool,
                'index': 1
            }
        }
        self.db = DictDB(schema, 'pk', 3)
        self.db.insert_ts('one', ts.TimeSeries([1, 2, 3], [1, 4, 9]))
        self.db.insert_ts('two', ts.TimeSeries([2, 3, 4], [4, 9, 16]))
        self.db.insert_ts('three', ts.TimeSeries([9, 3, 4], [4, 0, 16]))
        self.db.insert_ts('four', ts.TimeSeries([0, 0, 4], [1, 0, 4]))
        self.db.upsert_meta('one', {'order': 1, 'blarg': 1})
        self.db.upsert_meta('two', {'order': 2})
        self.db.upsert_meta('three', {'order': 1, 'blarg': 2})
        self.db.upsert_meta('four', {'order': 2, 'blarg': 2})
Exemple #5
0
def test_upsert():
    db = DictDB(schema, 'pk')

    db.insert_ts(1, ats1)
    db.insert_ts(2, ats1)

    db.upsert_meta(2, {'ts': ats2})
    db.upsert_meta(3, {'ts': ats2, 'not_there': 3, 'order': 1})

    rows = db.rows

    assert (rows[1]['ts'] == ats1)
    assert (rows[2]['ts'] == ats2)
    assert (rows[3]['ts'] == ats2)
    assert (rows[3]['order'] == 1)
    def test_protocol_delete(self):
        db = DictDB(schema, 'pk')
        server = TSDBServer(db)
        prot = TSDBProtocol(server)
    
        t1 = [0,1,2,3,4]
        v1 = [1.0,2.0,3.0,2.0,1.0]
        ats1 = ts.TimeSeries(t1, v1)
    
        t2 = [10,11,12,13,14]
        v2 = [-1.0,-2.0,-3.0,-2.0,-1.0]
        ats2 = ts.TimeSeries(t2, v2)

        insert_op = {}
        insert_op['pk'] = 1
        insert_op['ts'] = ats1
        insert_op['op'] = 'insert_ts'
    
        # Test Protocol Insert
        insert_return = prot._insert_ts(insert_op)
        assert(insert_return['op'] == 'insert_ts')
        assert(insert_return['status'] == TSDBStatus.OK)
        assert(insert_return['payload'] == None)
        inserted_row = server.db.rows[1]
        assert(inserted_row['pk'] == 1)
        assert(inserted_row['ts'] == ats1)

        insert_return2 = prot._insert_ts(insert_op)
        assert(insert_return2['op'] == 'insert_ts')
        assert(insert_return2['status'] == TSDBStatus.INVALID_KEY)

        delete_op = {}
        delete_op['pk'] = 1
        delete_op['op'] = 'delete_ts'

        delete_return = prot._delete_ts(delete_op)
        assert(delete_return['op'] == 'delete_ts')
        assert(delete_return['status'] == TSDBStatus.OK)
        assert(delete_return['payload'] == None)
        assert (len(server.db.rows) == 0)

        delete_return2 = prot._delete_ts(delete_op)
        assert(delete_return2['op'] == 'delete_ts')
        assert(delete_return2['status'] == TSDBStatus.INVALID_KEY)
Exemple #7
0
def test_insert():
    db = DictDB(schema, 'pk')

    t = [0, 1, 2, 3, 4]
    v = [1.0, 2.0, 3.0, 2.0, 1.0]
    ats = ts.TimeSeries(t, v)

    db.insert_ts(1, ats)

    rows = db.rows
    assert (rows[1] is not None)
    assert (rows[1]['pk'] == 1)
    assert (rows[1]['ts'] == ats)

    try:
        db.insert_ts(1, ats)
    except Exception as e:
        e1 = e
    assert str(e1) == 'Duplicate primary key found during insert'
    assert type(e1).__name__ == 'ValueError'
    def test_augmented_select(self):
        db = DictDB(schema, 'pk')
        server = TSDBServer(db)
        prot = TSDBProtocol(server)

        t1 = [0,1,2,3,4]
        v1 = [1.0,2.0,3.0,2.0,1.0]
        ats1 = ts.TimeSeries(t1, v1)

        t2 = [10,11,12,13,14]
        v2 = [-1.0,-2.0,-3.0,-2.0,-1.0]
        ats2 = ts.TimeSeries(t2, v2)

        insert_op = {}
        insert_op['pk'] = 1
        insert_op['ts'] = ats1
        insert_op['op'] = 'insert_ts'

        # Test Protocol Insert
        insert_return = prot._insert_ts(insert_op)
        assert(insert_return['op'] == 'insert_ts')
        assert(insert_return['status'] == TSDBStatus.OK)
        assert(insert_return['payload'] == None)
        inserted_row = server.db.rows[1]
        assert(inserted_row['pk'] == 1)
        assert(inserted_row['ts'] == ats1)

        # Test Protocol Select (None fields)
        metadata_dict = {'pk': {'>': 0}}
        fields = None
        additional = None
        aug_select_op = TSDBOp_AugmentedSelect('corr', ['mean', 'std'], [t2,v2], metadata_dict, additional )
        aug_select_return = prot._augmented_select(aug_select_op)

        assert(aug_select_return['op'] == 'augmented_select')
        assert(aug_select_return['status'] == TSDBStatus.OK)
        assert(aug_select_return['payload'] == {1: {'mean': 1.4142135623730403}})

        
Exemple #9
0
def test_select_basic_additional():
    db = DictDB(schema, 'pk')

    db.insert_ts(1, ats1)
    db.insert_ts(2, ats2)
    db.insert_ts(3, ats3)

    db.upsert_meta(1, {'useless': 1})
    db.upsert_meta(2, {'useless': 3})
    db.upsert_meta(3, {'useless': 5})

    # Limit to 2 results
    ids1, fields1 = db.select({'pk': {'>': 0}}, None, {'limit': 2})
    assert (ids1 == [1, 2])

    # Order Ascending
    ids2, fields2 = db.select({'pk': {'>': 0}}, None, {'sort_by': '+useless'})
    assert (ids2 == [1, 2, 3])

    # Order Descending
    ids3, fields3 = db.select({'pk': {'>': 0}}, None, {'sort_by': '-useless'})
    assert (ids3 == [3, 2, 1])
Exemple #10
0
def test_select_basic_fields():
    db = DictDB(schema, 'pk')

    db.insert_ts(1, ats1)
    db.insert_ts(2, ats2)
    db.insert_ts(3, ats3)

    db.upsert_meta(2, {'useless': 2})

    # One result
    ids1, fields1 = db.select({'pk': {'==': 1}}, ['ts'], None)
    assert (ids1 == [1])
    assert (fields1[0]['ts'] == ats1)

    # Two results
    ids2, fields2 = db.select({'pk': {'>': 1}}, ['ts'], None)
    assert (ids2 == [2, 3])
    assert (fields2[0]['ts'] == ats2)
    assert (fields2[1]['ts'] == ats3)

    # No results
    ids3, fields3 = db.select({'blarg': {'=': 1}}, ['ts'], None)
    assert (ids3 == [])

    # None Field List (just pks)
    ids4, fields4 = db.select({'pk': {'>': 0}}, None, None)
    assert (ids4 == [1, 2, 3])
    assert (fields4 == [{}, {}, {}])

    # Empty Field List (everything but ts)
    ids5, fields5 = db.select({'pk': {'>': 0}}, [], None)
    assert (ids5 == [1, 2, 3])
    assert (fields5 == [{'pk': 1}, {'pk': 2, 'useless': 2}, {'pk': 3}])

    # Named Field List (just that field)
    ids6, fields6 = db.select({'useless': {'>': 0}}, ['useless'], None)
    assert (ids6 == [2])
    assert (fields6 == [{'useless': 2}])
    def test_protocol_triggers(self):

        db = DictDB(schema, 'pk')
        server = TSDBServer(db)
        prot = TSDBProtocol(server)

        # Test Add Trigger
        add_trigger_op = TSDBOp_AddTrigger('stats', 'insert_ts', ['mean', 'std'], None)
        prot._add_trigger(add_trigger_op)

        mod = import_module('procs.stats')
        storedproc = getattr(mod,'main')

        assert(server.triggers['insert_ts'] ==  [('stats', storedproc, None, ['mean', 'std'])])


        # Test delete Trigger
        delete_trigger_op = TSDBOp_RemoveTrigger('stats', 'insert_ts')
        prot._remove_trigger(delete_trigger_op)

        mod = import_module('procs.stats')
        storedproc = getattr(mod,'main')

        assert(server.triggers['insert_ts'] ==  [])
Exemple #12
0
def test_complex():
    db = DictDB(schema, 'pk')

    for i in range(100):
        db.insert_ts(i, ats1)
        db.upsert_meta(i, {'useless': i})
        db.upsert_meta(i, {'order': -i})

    ids1, fields1 = db.select({'pk': {
        '>': 10,
        '<=': 50
    }}, None, {
        'limit': 10,
        'sort_by': '-useless'
    })
    assert (ids1 == [50, 49, 48, 47, 46, 45, 44, 43, 42, 41])

    ids2, fields2 = db.select(meta={},
                              fields=[],
                              additional={
                                  'limit': 15,
                                  'sort_by': '-order'
                              })
    assert (ids2 == [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14])
 def test_protocol(self):
     db = DictDB(schema, 'pk')
     server = TSDBServer(db)
     prot = TSDBProtocol(server)
 
     # Dumb server tests
     assert(server.db == db)
     assert(server.port == 9999)
 
     t1 = [0,1,2,3,4]
     v1 = [1.0,2.0,3.0,2.0,1.0]
     ats1 = ts.TimeSeries(t1, v1)
 
     t2 = [10,11,12,13,14]
     v2 = [-1.0,-2.0,-3.0,-2.0,-1.0]
     ats2 = ts.TimeSeries(t2, v2)
 
     # Test TSDBOp_InsertTS
     insert_op = {}
     insert_op['pk'] = 1
     insert_op['ts'] = ats1
     insert_op['op'] = 'insert_ts'
     InsertedTS = TSDBOp_InsertTS(1, ats1)
     assert(insert_op == InsertedTS)
 
     # Test Protocol Insert
     insert_return = prot._insert_ts(insert_op)
     assert(insert_return['op'] == 'insert_ts')
     assert(insert_return['status'] == TSDBStatus.OK)
     assert(insert_return['payload'] == None)
     inserted_row = server.db.rows[1]
     assert(inserted_row['pk'] == 1)
     assert(inserted_row['ts'] == ats1)
     
     # Add some more data
     prot._insert_ts(TSDBOp_InsertTS(2, ats1))
     inserted_row = server.db.rows[2]
     assert(inserted_row['ts'] == ats1)
     
     # Test Protocol Upsert
     upserted_meta = TSDBOp_UpsertMeta(2, {'ts': ats2, 'order': 1})
     upsert_return = prot._upsert_meta(upserted_meta)
     assert(upsert_return['op'] == 'upsert_meta')
     assert(upsert_return['status'] == TSDBStatus.OK)
     assert(upsert_return['payload'] == None)
 
     # Test Protocol Select (None fields)
     metadata_dict = {'pk': {'>': 0}}
     fields = None
     additional = None
     select_op = TSDBOp_Select(metadata_dict, fields, additional)
     select_return = prot._select(select_op)
     print("Here", select_return)
     assert(select_return['op'] == 'select')
     assert(select_return['status'] == TSDBStatus.OK)
     assert(select_return['payload'][1] == {})
     assert(select_return['payload'][2] == {})
     
     # Test Protocol Select
     metadata_dict = {'pk': {'>': 0}}
     fields = ['ts']
     additional = None
     select_op = TSDBOp_Select(metadata_dict, fields, additional)
     select_return = prot._select(select_op)
     assert(select_return['op'] == 'select')
     assert(select_return['status'] == TSDBStatus.OK)
     assert(select_return['payload'][1]['ts'] == ats1)
     assert(select_return['payload'][2]['ts'] == ats2)
     
     # Test Add Trigger
     add_trigger_op = TSDBOp_AddTrigger('stats', 'insert_ts', ['mean', 'std'], None)
     prot._add_trigger(add_trigger_op)
     
     mod = import_module('procs.stats')
     storedproc = getattr(mod,'main')
     
     assert(server.triggers['insert_ts'] ==  [('stats', storedproc, None, ['mean', 'std'])])