Beispiel #1
0
def create_bucket(name, datagroup, datatype, rawqueries=False, token=None,
                  autoids=None, uploadformat=None, uploadfilters=None,
                  queryable=True, realtime=False):
    """Create a new bucket configuration in the database."""
    db = get_database()

    config = BucketConfig(name=name, data_group=datagroup, data_type=datatype,
                          raw_queries_allowed=rawqueries, bearer_token=token,
                          upload_format=uploadformat,
                          upload_filters=uploadfilters, auto_ids=autoids,
                          queryable=queryable, realtime=realtime)
    repository = BucketConfigRepository(db)

    repository.save(config)
Beispiel #2
0
 def setUp(self):
     # This is a bit of a smell. Mongo collection responsibilites should be
     # split with repo, once we have more than one repository.
     self.db = Mock()
     self.mongo_collection = Mock()
     self.db.get_collection.return_value = self.mongo_collection
     self.bucket_repo = BucketConfigRepository(self.db)
Beispiel #3
0
class TestBucketRepository(unittest.TestCase):
    def setUp(self):
        # This is a bit of a smell. Mongo collection responsibilites should be
        # split with repo, once we have more than one repository.
        self.db = Mock()
        self.mongo_collection = Mock()
        self.db.get_collection.return_value = self.mongo_collection
        self.bucket_repo = BucketConfigRepository(self.db)

    def test_saving_a_bucket(self):
        bucket = BucketConfig("bucket_name", data_group="data_group", data_type="type")

        self.bucket_repo.save(bucket)
        self.mongo_collection.save.assert_called_with(match_equality(has_entries({
            "_id": "bucket_name",
            "name": "bucket_name",
            "data_group": "data_group",
            "data_type": "type",
            "raw_queries_allowed": False,
            "bearer_token": None,
            "upload_format": "csv",
        })))

    def test_saving_a_bucket_with_some_attributes(self):
        bucket = BucketConfig("bucket_name",
                              data_group="data_group", data_type="type",
                              raw_queries_allowed=True,
                              upload_format="excel")

        self.bucket_repo.save(bucket)
        self.mongo_collection.save.assert_called_with(match_equality(has_entries({
            "_id": "bucket_name",
            "name": "bucket_name",
            "data_group": "data_group",
            "data_type": "type",
            "raw_queries_allowed": True,
            "bearer_token": None,
            "upload_format": "excel",
        })))

    def test_saving_fails_with_non_bucket_object(self):
        not_bucket = {"foo": "bar"}

        assert_raises(ValueError, self.bucket_repo.save, not_bucket)

    def test_saving_fails_with_non_bucket_namedtuple(self):
        NotBucket = namedtuple("NotBucket", "name raw_queries_allowed")
        not_bucket = NotBucket("name", True)
        assert_raises(ValueError, self.bucket_repo.save, not_bucket)

    def test_bucket_config_is_created_from_retrieved_data(self):
        self.mongo_collection.find_one.return_value = {
            "_id": "bucket_name",
            "name": "bucket_name",
            "data_group": "data_group",
            "data_type": "type",
            "raw_queries_allowed": False,
            "bearer_token": "my-bearer-token",
            "upload_format": "excel"
        }
        bucket = self.bucket_repo.retrieve(name="bucket_name")
        expected_bucket = BucketConfig("bucket_name",
                                       data_group="data_group", data_type="type",
                                       raw_queries_allowed=False,
                                       bearer_token="my-bearer-token",
                                       upload_format="excel")

        assert_that(bucket, equal_to(expected_bucket))

    def test_saving_a_realtime_bucket_creates_a_capped_collection(self):
        capped_bucket = BucketConfig("capped_bucket",
                                     data_group="data_group", data_type="type",
                                     realtime=True, capped_size=7665)

        self.bucket_repo.save(capped_bucket)

        self.db.create_capped_collection.assert_called_with("capped_bucket", 7665)

    def test_saving_a_realtime_bucket_does_not_create_a_collection_if_creation_flag_is_off(self):
        capped_bucket = BucketConfig("capped_bucket",
                                     data_group="data_group", data_type="type",
                                     realtime=True, capped_size=7665)

        self.bucket_repo.save(capped_bucket, create_bucket=False)

        assert not self.db.create_capped_collection.called

    def test_retrieving_non_existent_bucket_returns_none(self):
        self.mongo_collection.find_one.return_value = None
        bucket = self.bucket_repo.retrieve(name="bucket_name")

        assert_that(bucket, is_(None))
Beispiel #4
0
 def setUp(self):
     self.db = Database(HOST, PORT, DB_NAME)
     self.db._mongo.drop_database(DB_NAME)
     self.mongo_collection = self.db.get_collection(BUCKET)
     self.repository = BucketConfigRepository(self.db)
Beispiel #5
0
class TestBucketRepositoryIntegration(unittest.TestCase):

    def setUp(self):
        self.db = Database(HOST, PORT, DB_NAME)
        self.db._mongo.drop_database(DB_NAME)
        self.mongo_collection = self.db.get_collection(BUCKET)
        self.repository = BucketConfigRepository(self.db)

    def test_saving_a_config_with_default_values(self):
        config = BucketConfig("some_bucket", data_group="group", data_type="type")

        self.repository.save(config)

        results = list(self.mongo_collection._collection.find())

        assert_that(len(results), is_(1))
        assert_that(results[0], has_entries({
            "name": "some_bucket",
            "raw_queries_allowed": False,
            "bearer_token": None,
            "upload_format": "csv"
        }))

    def test_saving_a_realtime_config_creates_a_capped_collection(self):
        config = BucketConfig("realtime_bucket", data_group="group", data_type="type", realtime=True)

        self.repository.save(config)

        assert_that(self.db.mongo_database["realtime_bucket"].options(), is_({"capped": True, "size": 5040}))

    def test_retrieves_config_by_name(self):
        self.repository.save(BucketConfig("not_my_bucket", data_group="group", data_type="type"))
        self.repository.save(BucketConfig("my_bucket", data_group="group", data_type="type"))
        self.repository.save(BucketConfig("someones_bucket", data_group="group", data_type="type"))

        config = self.repository.retrieve(name="my_bucket")

        assert_that(config.name, is_("my_bucket"))

    def test_retrieves_config_for_service_and_data_type(self):
        self.repository.save(BucketConfig("b1", data_group="my_service", data_type="my_type"))
        self.repository.save(BucketConfig("b2", data_group="my_service", data_type="not_my_type"))
        self.repository.save(BucketConfig("b3", data_group="not_my_service", data_type="my_type"))

        config = self.repository.get_bucket_for_query(data_group="my_service", data_type="my_type")

        assert_that(config.name, is_("b1"))