class TestSeriesService:
    def setup(self):

        self.connection_string = "sqlite:///:memory:"
        self.series_service = SeriesService(connection_string=self.connection_string, debug=False)

        engine = self.series_service._session_factory.engine
        test_util.build_db(engine)

        self.memory_database = MemoryDatabase()
        self.memory_database.set_series_service(self.series_service)
        self.session = self.memory_database.series_service._session_factory.get_session()

        self.series = test_util.add_series_bulk_data(self.session)
        #assert len(self.series.data_values) == 100

        self.edit_service =EditService(1, connection= self.memory_database)


    ## TODO Unittest save_series, save_as, save_as_existing

    def test_save_series(self):
        assert self.edit_service.save()

    def test_save_as_series(self):
        var = test_util.add_variable(self.session)
        print var
        assert self.edit_service.save_as(var= var)
        ##assert self.edit_service.memDB.series_service.series_exists(self.series.site.id, var, self.series.method.id,
        #                                         self.series.source.id, self.series.qcl.id)


    def test_save_as_existing_series(self):
        var = test_util.add_variable(self.session)
        assert self.edit_service.save_existing(var = var)
Example #2
0
class TestSeriesService:
    def setup(self):

        self.connection_string = "sqlite:///:memory:"
        self.series_service = SeriesService(
            connection_string=self.connection_string, debug=False)

        engine = self.series_service._session_factory.engine
        test_util.build_db(engine)

        self.memory_database = MemoryDatabase()
        self.memory_database.set_series_service(self.series_service)
        self.session = self.memory_database.series_service._session_factory.get_session(
        )

        self.series = test_util.add_series_bulk_data(self.session)
        #assert len(self.series.data_values) == 100

        self.edit_service = EditService(1, connection=self.memory_database)

    def test_save_series(self):
        assert self.edit_service.save()

    def test_save_as_series(self):
        var = test_util.add_variable(self.session)
        print var
        assert self.edit_service.save_as(var=var)
        ##assert self.edit_service.memDB.series_service.series_exists(self.series.site.id, var, self.series.method.id,
        #                                         self.series.source.id, self.series.qcl.id)

    def test_save_as_existing_series(self):
        var = test_util.add_variable(self.session)
        assert self.edit_service.save_existing(var=var)
class TestSeriesService:
    def setup(self):

        self.connection_string = "sqlite:///:memory:"
        self.series_service = SeriesService(
            connection_string=self.connection_string, debug=False)

        engine = self.series_service._session_factory.engine
        test_util.build_db(engine)

        self.memory_database = MemoryDatabase()
        self.memory_database.set_series_service(self.series_service)
        self.session = self.memory_database.series_service._session_factory.get_session(
        )

        self.series = test_util.add_series_bulk_data(self.session)
        #assert len(self.series.data_values) == 100

        self.edit_service = EditService(1, connection=self.memory_database)
        """
        @pytest.fixture(scope="class", autouse=True)
    def build_db(self):
        """
        #Builds an empty sqlite (in-memory) database for testing
        #:return: None
        """
        # path to the ddl script for building the database
        ddlpath= abspath(join(dirname(__file__), 'data/empty.sql'))

        # create and empty sqlite database for testing
        db = dbconnection.createConnection('sqlite', ':memory:')

        # read the ddl script and remove the first (BEGIN TRANSACTION) and last (COMMIT) lines
        ddl = open(ddlpath, 'r').read()
        ddl = ddl.replace('BEGIN TRANSACTION;','')
        ddl = ddl.replace('COMMIT;','')

        # execute each statement to build the odm2 database
        for line in ddl.split(');')[:-1]:
            try:
                db.engine.execute(line + ');')
            except Exception as e:
                print e

        self.write = CreateODM2(db)
        self.engine= db.engine

        globals['write'] = self.write
        globals['engine'] = self.engine
        globals['db'] = db
        # return self.write, self.engine

    def setup(self):

        self.writer = globals['write']
        self.engine = globals['engine']
        self.db = globals['db']
        """

    def test_duplicate_values_filter(self):
        duplicate_value = self.memory_database.getDataValues()[0]
        self.memory_database.addPoints(duplicate_value)
        vals = self.edit_service.duplicate_value_filter()
        assert len(vals) == 1

    def test_save_series(self):
        stlen = len(self.series.data_values)
        assert self.edit_service.save()
        val = self.series_service.get_series_by_id(self.series.id)
        assert len(val.data_values) == stlen

    def test_save_as_series(self):
        var = test_util.add_variable(self.session)
        print var
        stlen = len(self.series.data_values)
        assert self.edit_service.save_as(var=var)
        assert self.edit_service.memDB.series_service.series_exists_quint(
            self.series.site_id, var.id, self.series.method_id,
            self.series.source_id, self.series.quality_control_level_id)

    def test_save_as_existing_series(self):
        var = test_util.add_variable(self.session)
        assert self.edit_service.save_existing(var=var)

    def test_save_append_keep(self):
        #TODO add custon test

        len1 = len(self.series.data_values)
        # keep data from original series if overlap:

        svalue = self.series.data_values[0]

        self.edit_service.memDB.updateValue([svalue.local_date_time], '+', 5)
        news = self.edit_service.memDB.series_service.get_series_by_id(
            self.series.id)
        result = self.edit_service.save_appending(overwrite=False)
        len2 = len(self.series.data_values)
        assert len1 == len2
        assert news.data_values[0].data_value == svalue.data_value
        assert result

    def test_save_append_overwrite(self):
        len1 = len(self.series.data_values)
        svalue = self.series.data_values[0]

        self.edit_service.memDB.updateValue([svalue.local_date_time], '+', 5)
        news = self.edit_service.memDB.series_service.get_series_by_id(
            self.series.id)
        result = self.edit_service.save_appending(overwrite=True)
        len2 = len(self.series.data_values)
        assert len1 == len2
        assert news.data_values[0].data_value == svalue.data_value + 5
        assert result
Example #4
0
class TestSeriesService:
    def setup(self):

        self.connection_string = "sqlite:///:memory:"
        self.series_service = SeriesService(connection_string=self.connection_string, debug=False)

        engine = self.series_service._session_factory.engine
        test_util.build_db(engine)

        self.memory_database = MemoryDatabase()
        self.memory_database.set_series_service(self.series_service)
        self.session = self.memory_database.series_service._session_factory.get_session()

        self.series = test_util.add_series_bulk_data(self.session)
        #assert len(self.series.data_values) == 100

        self.edit_service =EditService(1, connection= self.memory_database)


        """
        @pytest.fixture(scope="class", autouse=True)
    def build_db(self):
        """
        #Builds an empty sqlite (in-memory) database for testing
        #:return: None
        """
        # path to the ddl script for building the database
        ddlpath= abspath(join(dirname(__file__), 'data/empty.sql'))

        # create and empty sqlite database for testing
        db = dbconnection.createConnection('sqlite', ':memory:')

        # read the ddl script and remove the first (BEGIN TRANSACTION) and last (COMMIT) lines
        ddl = open(ddlpath, 'r').read()
        ddl = ddl.replace('BEGIN TRANSACTION;','')
        ddl = ddl.replace('COMMIT;','')

        # execute each statement to build the odm2 database
        for line in ddl.split(');')[:-1]:
            try:
                db.engine.execute(line + ');')
            except Exception as e:
                print e

        self.write = CreateODM2(db)
        self.engine= db.engine

        globals['write'] = self.write
        globals['engine'] = self.engine
        globals['db'] = db
        # return self.write, self.engine

    def setup(self):

        self.writer = globals['write']
        self.engine = globals['engine']
        self.db = globals['db']
        """

    def test_duplicate_values_filter(self):
        duplicate_value = self.memory_database.getDataValues()[0]
        self.memory_database.addPoints(duplicate_value)
        vals = self.edit_service.duplicate_value_filter()
        assert len(vals) == 1

    def test_save_series(self):
        stlen = len(self.series.data_values)
        assert self.edit_service.save()
        val = self.series_service.get_series_by_id(self.series.id)
        assert len(val.data_values)==stlen

    def test_save_as_series(self):
        var = test_util.add_variable(self.session)
        print var
        stlen = len(self.series.data_values)
        assert self.edit_service.save_as(var= var)
        assert self.edit_service.memDB.series_service.series_exists_quint(self.series.site_id, var.id, self.series.method_id, self.series.source_id, self.series.quality_control_level_id)

    def test_save_as_existing_series(self):
        var = test_util.add_variable(self.session)
        assert self.edit_service.save_existing(var = var)

    def test_save_append_keep(self):
        #TODO add custon test

        len1= len(self.series.data_values)
        # keep data from original series if overlap:


        svalue = self.series.data_values[0]

        self.edit_service.memDB.updateValue([svalue.local_date_time],'+', 5 )
        news= self.edit_service.memDB.series_service.get_series_by_id(self.series.id)
        result = self.edit_service.save_appending(overwrite = False)
        len2= len(self.series.data_values)
        assert len1 == len2
        assert news.data_values[0].data_value == svalue.data_value
        assert result

    def test_save_append_overwrite(self):
        len1= len(self.series.data_values)
        svalue = self.series.data_values[0]

        self.edit_service.memDB.updateValue([svalue.local_date_time],'+', 5)
        news= self.edit_service.memDB.series_service.get_series_by_id(self.series.id)
        result = self.edit_service.save_appending(overwrite = True)
        len2= len(self.series.data_values)
        assert len1 == len2
        assert news.data_values[0].data_value == svalue.data_value + 5
        assert result