Exemple #1
0
def create_kafka_producer_with_schema(schema, protocol):
    avro_schema = get_schema(protocol, schema)
    producer = AIOKafkaProducer(
        loop=asyncio.get_event_loop(),
        value_serializer=partial(serialize, schema=avro_schema),
        bootstrap_servers=os.environ['kafka_bootstrap_servers'])

    DataStoreFactory.scenario_data_store().put('producer', producer)
 def signup(self):
     user_name = 'user_{}'.format(time.mktime(datetime.datetime.now().timetuple()))
     self.set(SignUpPageLocators.USER_NAME, user_name)
     self.set(SignUpPageLocators.EMAIL, '{}@gmail.com'.format(user_name))
     self.set(SignUpPageLocators.PASSWORD, 'password')
     self.set(SignUpPageLocators.CONFIRM_PASSWORD, 'password')
     self.click(SignUpPageLocators.SUBMIT)
     DataStoreFactory.scenario_data_store().put('current_user', user_name)
Exemple #3
0
 def signup(self):
     user_name = 'user_{}'.format(
         time.mktime(datetime.datetime.now().timetuple()))
     self.set(SignUpPageLocators.USER_NAME, user_name)
     self.set(SignUpPageLocators.EMAIL, '{}@gmail.com'.format(user_name))
     self.set(SignUpPageLocators.PASSWORD, 'password')
     self.set(SignUpPageLocators.CONFIRM_PASSWORD, 'password')
     self.click(SignUpPageLocators.SUBMIT)
     DataStoreFactory.scenario_data_store().put('current_user', user_name)
Exemple #4
0
def consume_messages_with_timeout(number_messages, timeout):
    consumer = DataStoreFactory.scenario_data_store().get('consumer')
    loop = asyncio.get_event_loop()
    messages = loop.run_until_complete(
        _consume_messages(consumer, int(number_messages), int(timeout)))

    assert len(messages) == int(
        number_messages
    ), f'{len(messages)} messages found, expected {int(number_messages)}'

    DataStoreFactory.scenario_data_store().put('messages', messages)
Exemple #5
0
def create_kafka_consumer_with_schema_listening_to_topic(
        schema, protocol, topic):
    avro_schema = get_schema(protocol, schema)
    consumer = AIOKafkaConsumer(
        topic,
        loop=asyncio.get_event_loop(),
        group_id='acceptance_tests_group_id',
        value_deserializer=partial(deserialize, schema=avro_schema),
        bootstrap_servers=os.environ['kafka_bootstrap_servers'],
        auto_offset_reset='earliest')

    DataStoreFactory.scenario_data_store().put('consumer', consumer)
    def test_Processor_scenario_data_store_init_request(self):
        DataStoreFactory.scenario_data_store().put('scenario', 'value')

        self.assertNotEqual(DataStore(), DataStoreFactory.scenario_data_store())

        response = Message()
        processors[Message.ScenarioDataStoreInit](None, response, None)

        self.assertEqual(Message.ExecutionStatusResponse, response.messageType)
        self.assertEqual(False, response.executionStatusResponse.executionResult.failed)
        self.assertEqual(0, response.executionStatusResponse.executionResult.executionTime)

        self.assertEqual(DataStore(), DataStoreFactory.scenario_data_store())
    def test_Processor_scenario_data_store_init_request(self):
        DataStoreFactory.scenario_data_store().put('scenario', 'value')

        self.assertNotEqual(DataStore(), DataStoreFactory.scenario_data_store())

        response = Message()
        processors[Message.ScenarioDataStoreInit](None, response, None)

        self.assertEqual(Message.ExecutionStatusResponse, response.messageType)
        self.assertEqual(False, response.executionStatusResponse.executionResult.failed)
        self.assertEqual(0, response.executionStatusResponse.executionResult.executionTime)

        self.assertEqual(DataStore(), DataStoreFactory.scenario_data_store())
Exemple #8
0
def asserts_messages_contains(table):
    message_asserts = [dict(zip(table.headers, row)) for row in table]
    messages = DataStoreFactory.scenario_data_store().get('messages')
    for message, asserts in zip(messages, message_asserts):
        for key, value in asserts.items():
            assert str(
                message[key]
            ) == value, f'Value "{message[key]}" differs from expected "{value}"'
    def test_data_store_factory(self):
        scenario_data_store = DataStoreFactory.scenario_data_store()
        spec_data_store = DataStoreFactory.spec_data_store()
        suite_data_store = DataStoreFactory.suite_data_store()

        data_store = DataStore()

        self.assertEqual(data_store, scenario_data_store)
        self.assertEqual(data_store, spec_data_store)
        self.assertEqual(data_store, suite_data_store)
Exemple #10
0
def produce_messages(topic, table):
    messages = [
        dict(
            zip(table.headers,
                [row[0], row[1],
                 int(row[2]), int(row[3]), row[4]])) for row in table
    ]
    producer = DataStoreFactory.scenario_data_store().get('producer')
    loop = asyncio.get_event_loop()
    loop.run_until_complete(_produce_messages(producer, topic, messages))
Exemple #11
0
    def test_data_store_factory(self):
        scenario_data_store = DataStoreFactory.scenario_data_store()
        spec_data_store = DataStoreFactory.spec_data_store()
        suite_data_store = DataStoreFactory.suite_data_store()

        data_store = DataStore()

        self.assertEqual(data_store, scenario_data_store)
        self.assertEqual(data_store, spec_data_store)
        self.assertEqual(data_store, suite_data_store)
Exemple #12
0
    def test_data_store_factory_as_proxy(self):
        stores = [
            (data_store.scenario, DataStoreFactory.scenario_data_store()),
            (data_store.spec, DataStoreFactory.spec_data_store()),
            (data_store.suite, DataStoreFactory.suite_data_store()),
        ]
        for (store, proxy) in stores:
            store['a'] = 'alpha'
            self.assertTrue(proxy.is_present('a'))
            self.assertEqual(proxy.get('a'), store['a'])

            proxy.put('b', 'beta')
            self.assertIn('b', store)
            self.assertEqual(store['b'], proxy.get('b'))

            proxy.clear()
            self.assertDictEqual(store, {})
Exemple #13
0
def _init_scenario_data_store(request, response, socket):
    DataStoreFactory.scenario_data_store().clear()
    set_response_values(request, response)
Exemple #14
0
 def setUp(self):
     self.setUpPyfakefs()
     DataStoreFactory.suite_data_store().clear()
     DataStoreFactory.spec_data_store().clear()
     DataStoreFactory.scenario_data_store().clear()
     registry.clear()
 def save_product_id(self):
     DataStoreFactory.scenario_data_store().put('product_id', self.get(ProductPageLocators.ID))
Exemple #16
0
 def visit(self):
     self.driver.get(
         self.URL.format(
             id=DataStoreFactory.scenario_data_store().get('product_id')))
 def setUp(self):
     DataStoreFactory.suite_data_store().clear()
     DataStoreFactory.spec_data_store().clear()
     DataStoreFactory.scenario_data_store().clear()
     registry.clear()
 def visit(self):
     self.driver.get(self.URL.format(id=DataStoreFactory.scenario_data_store().get('product_id')))
 def save_product_id(self):
     DataStoreFactory.scenario_data_store().put(
         'product_id', self.get(ProductPageLocators.ID))
def _init_scenario_data_store(request, response, _socket):
    DataStoreFactory.scenario_data_store().clear()
    set_response_values(request, response)
Exemple #21
0
def verify_registered_customer_is_listed():
    PageFactory.customer_page.verify_user_listed(DataStoreFactory.scenario_data_store().get('current_user'))