Example #1
0
 def test_achievements_length(self):
     docgen = NewNestedDocument(avg_size=0)
     for k in range(100000):
         key = '%012d' % k
         doc = docgen.next(key)
         self.assertLessEqual(len(doc['achievements']), 10)
         self.assertGreater(len(doc['achievements']), 0)
Example #2
0
 def test_achievements_length(self):
     docgen = NewNestedDocument(avg_size=0)
     for k in range(100000):
         key = '%012d' % k
         doc = docgen.next(key)
         self.assertLessEqual(len(doc['achievements']), 10)
         self.assertGreater(len(doc['achievements']), 0)
Example #3
0
 def test_query_formatting(self):
     docgen = NewNestedDocument(avg_size=self.SIZE)
     doc = docgen.next('test-key')
     queries = ['SELECT * from `bucket-1`;', 'SELECT count(*) from `bucket-1`;']
     qgen = N1QLQueryGen(queries=queries)
     _, _, query = qgen.next(doc)
     query.format(bucket='bucket-1')
Example #4
0
 def test_gmtime_variation(self):
     docgen = NewNestedDocument(avg_size=0)
     keys = set()
     for k in range(1000):
         key = '%012d' % k
         doc = docgen.next(key)
         keys.add(doc['gmtime'])
     self.assertEqual(len(keys), 12)
Example #5
0
 def test_gmtime_variation(self):
     docgen = NewNestedDocument(avg_size=0)
     keys = set()
     for k in range(1000):
         key = '%012d' % k
         doc = docgen.next(key)
         keys.add(doc['gmtime'])
     self.assertEqual(len(keys), 12)
Example #6
0
 def test_query_formatting(self):
     docgen = NewNestedDocument(avg_size=self.SIZE)
     doc = docgen.next('test-key')
     queries = [
         'SELECT * from `bucket-1`;', 'SELECT count(*) from `bucket-1`;'
     ]
     qgen = N1QLQueryGen(queries=queries)
     _, _, query = qgen.next(doc)
     query.format(bucket='bucket-1')
Example #7
0
 def test_doc_content(self):
     docgen = NewNestedDocument(avg_size=0)
     actual = docgen.next(key='000000000020')
     expected = {
         'name': {
             'f': {
                 'f': {
                     'f': 'ecdb3e e921c9'
                 }
             }
         },
         'email': {
             'f': {
                 'f': '*****@*****.**'
             }
         },
         'street': {
             'f': {
                 'f': '400f1d0a'
             }
         },
         'city': {
             'f': {
                 'f': '90ac48'
             }
         },
         'county': {
             'f': {
                 'f': '40efd6'
             }
         },
         'state': {
             'f': 'WY'
         },
         'full_state': {
             'f': 'Montana'
         },
         'country': {
             'f': '1811db'
         },
         'realm': {
             'f': '15e3f5'
         },
         'coins': {
             'f': 213.54
         },
         'category': 1,
         'achievements': [0, 135, 92],
         'gmtime': (1972, 3, 3, 0, 0, 0, 4, 63, 0),
         'year': 1989,
         'body': '',
         'capped_small': '100_0',
         'capped_large': '3000_0',
     }
     self.assertEqual(actual, expected)
Example #8
0
 def test_doc_size(self):
     docgen = NewNestedDocument(avg_size=self.SIZE)
     sizes = tuple(
         len(json.dumps(docgen.next(key='%012s' % i)))
         for i in range(10000))
     mean = np.mean(sizes)
     self.assertAlmostEqual(mean, 1152, delta=128)
     p95 = np.percentile(sizes, 97)
     self.assertLess(p95, 2048)
     p99 = np.percentile(sizes, 98)
     self.assertGreater(p99, 2048)
     self.assertLess(max(sizes), 2 * 1024**2)
     self.assertGreater(min(sizes), 0)
Example #9
0
 def test_doc_size(self):
     docgen = NewNestedDocument(avg_size=self.SIZE)
     sizes = tuple(
         len(json.dumps(docgen.next(key='%012s' % i)))
         for i in range(10000)
     )
     mean = np.mean(sizes)
     self.assertAlmostEqual(mean, 1024, delta=128)
     p95 = np.percentile(sizes, 97)
     self.assertLess(p95, 2048)
     p99 = np.percentile(sizes, 98)
     self.assertGreater(p99, 2048)
     self.assertLess(max(sizes), 2 * 1024 ** 2)
     self.assertGreater(min(sizes), 0)
Example #10
0
class SpringLatency(Latency):

    COLLECTOR = "spring_latency"

    METRICS = ("latency_set", "latency_get")

    def __init__(self, settings, workload, prefix=None):
        super(Latency, self).__init__(settings)
        self.clients = []
        for bucket in self.get_buckets():
            client = CBGen(bucket=bucket, host=settings.master_node,
                           username=bucket, password=settings.bucket_password)
            self.clients.append((bucket, client))

        self.existing_keys = ExistingKey(workload.working_set,
                                         workload.working_set_access,
                                         prefix=prefix)
        if not hasattr(workload, 'doc_gen') or workload.doc_gen == 'old':
            self.new_docs = NewDocument(workload.size)
        else:
            self.new_docs = NewNestedDocument(workload.size)
        self.items = workload.items

    def measure(self, client, metric):
        key = self.existing_keys.next(curr_items=self.items, curr_deletes=0)
        doc = self.new_docs.next(key)

        t0 = time()
        if metric == "latency_set":
            client.create(key, doc)
        elif metric == "latency_get":
            client.read(key)
        elif metric == "latency_cas":
            client.cas(key, doc)
        return 1000 * (time() - t0)  # Latency in ms

    def sample(self):
        for bucket, client in self.clients:
            samples = {}
            for metric in self.METRICS:
                samples[metric] = self.measure(client, metric)
            self.store.append(samples, cluster=self.cluster,
                              bucket=bucket, collector=self.COLLECTOR)
Example #11
0
 def test_doc_content(self):
     docgen = NewNestedDocument(avg_size=0)
     actual = docgen.next(key='000000000020')
     expected = {
         'name': {'f': {'f': {'f': 'ecdb3e e921c9'}}},
         'email': {'f': {'f': '*****@*****.**'}},
         'street': {'f': {'f': '400f1d0a'}},
         'city': {'f': {'f': '90ac48'}},
         'county': {'f': {'f': '40efd6'}},
         'state': {'f': 'WY'},
         'full_state': {'f': 'Montana'},
         'country': {'f': '1811db'},
         'realm': {'f': '15e3f5'},
         'coins': {'f': 213.54},
         'category': 1,
         'achievements': [0, 135, 92],
         'gmtime': (1972, 3, 3, 0, 0, 0, 4, 63, 0),
         'year': 1989,
         'body': '',
     }
     self.assertEqual(actual, expected)
Example #12
0
 def test_determenistic(self):
     docgen = NewNestedDocument(avg_size=self.SIZE)
     d1 = docgen.next(key='mykey')
     d2 = docgen.next(key='mykey')
     d1['body'] = d2['body'] = None
     self.assertEqual(d1, d2)
Example #13
0
def run(keys):
    docs = NewNestedDocument(avg_size=1024)
    for key in keys:
        docs.next(key)
Example #14
0
 def test_determenistic(self):
     docgen = NewNestedDocument(avg_size=self.SIZE)
     d1 = docgen.next(key='mykey')
     d2 = docgen.next(key='mykey')
     d1['body'] = d2['body'] = None
     self.assertEqual(d1, d2)