A message producer, that generates messages randomly for testing purposes.
This will start up the generator together with Kafka and ZooKeeper
docker-compose up -d
Additionally to the previous command, it will start the app message_generator/test_receiver.py
. (This is useful for checking if the Kafka setting actually works).
docker-compose -f docker-compose-with-testreceiver.yaml up -d
You can read the logs as follows:
docker logs -ft test-receiver
Here you have to provide the environment variables and install the dependencies manually.
pip3 install -r requirements.txt
source environ.sh
python3 message_generator/__main__.py
This will start up a testing environment (Kafka and ZooKeeper) and run all tests. Afterwards the test environment is stopped
./bin/test.sh
We assume that the test_message_generator is deployed with MICO, therefore it is running in namespace mico-workspace
.
Get logs:
kubectl -n mico-workspace logs -f $(kubectl get pods -n mico-workspace -l ust.mico/name=test-message-generator --output=jsonpath={.items..metadata.name})
Get environment variables:
kubectl -n mico-workspace exec -it $(kubectl get pods -n mico-workspace -l ust.mico/name=test-message-generator --output=jsonpath={.items..metadata.name}) env
Restart:
kubectl -n mico-workspace delete pod $(kubectl get pods -n mico-workspace -l ust.mico/name=test-message-generator --output=jsonpath={.items..metadata.name})
Manually change the deployment image:
kubectl set image deployment/$(kubectl get deployments -n mico-workspace -l ust.mico/name=test-message-generator --output=jsonpath={.items..metadata.name}) test-message-generator=ustmico/message-generator:local -n mico-workspace
Variable | Implementation Strategy | default |
---|---|---|
LOG_FILE_PATH | Path to the file, in which the logs are stored | <workdir>/test_message_generator.log</workdir> |
LOG_FORMAT | The format of the logs. Format variables are described here | %(asctime)-15s %(message)s |
LOG_LEVEL | The log level. Supported values (INFO, DEBUG) | INFO |
MESSAGE_SOURCE | The value that is used in every message for the CloudEvent field 'source' | test_message_generator_ + <random uuid> |
MESSAGE_SEND_INTERVAL | The number of seconds between each message | 5 |
KAFKA_TOPIC_OUTPUT | The topic, to which each message is published | test-message-generator |
KAFKA_TOPIC_OUTPUT_REPLICATION_FACTOR | The replication factor of the target topic. Only applied, when the message generator has to create the topic manually | 1 |
KAFKA_TOPIC_OUTPUT_NUM_PARTITIONS | The number of partitions of the target topic. Only applied, when the message generator has to create the topic manually | 1 |
KAFKA_BOOTSTRAP_SERVERS | The domain and port of the Kafka broker | localhost:9092 |