Limitation in code buckets and tests
Hello,
We are currently using a multi-DB setup for our stores (DE
, EN
, CH
), where each store has its own database. When running tests via docker/sdk cli -t
or docker/sdk testing
, the default store is used. In our case, it is DE
(as defined in the deploy.yml
file under docker:testing:store:
).
We have reached a point where we need to run tests in the context of EN
or CH
to verify if the code buckets for EN
/CH
logic are functioning correctly. Unfortunately, we haven’t found a way to enter the test mode while providing the store context, as the value of DE
is hardcoded into a .env file when bootstrapping the project.
When entering the CLI via APPLICATION_STORE=EN docker/sdk cli
, we can see in the terminal's output that the store is set to EN
, which means, we can set the current context for the cli. However, when running APPLICATION_STORE=EN docker/sdk cli -t
or APPLICATION_STORE=EN docker/sdk testing
the store context reverts to DE
(the default store) and APPLICATION_STORE
is ignored. Which looks like, there is no way to set the default store from outside to run the tests.
We got following suggestions by the sprykers support team in the partners portal so far:
Option one
If you specify APPLICATION_STORE=EN before test execution command, it should probably work.
docker/sdk testing APPLICATION_STORE=AT console queue:worker:start --stop-when-empty
This is not working, since we are getting propel exceptions, because the database configs are not aligned. In this approach we are still in the DE
store context and only providing the APPLICATION_STORE
before the test command, which has no effect for the cli.
Option two
We also suggest having several deploy.yml with different settings for testing different stores:
Firstdocker:testing:store: DESecond
docker:testing:store: ENThird
docker:testing:store: CH
This is not working, because we are expecting more than 20 different stores, which would lead to have more than 20 deploy.ymls to run tests. This would also mean, that we would need to bootstrap each time, we are changing something in another store context, to run tests.
Option three
I would also like to inform you about our platform CommerceQuest (), it is a community where you can post problems or questions and that would be answered by community experts.
Since we got no better idea, we would like to ask, if you had similar challenges, when running tests in the context of a different code bucket.
I am happy to get any support and other ideas about that topic.
Thank you
Answers
-
I can confirm, that on some projects with multistore setup, there are more than one deploy file per store.
I'm researching internally if we can help you with the situation, when the number of stores is huge.
1 -
Hey @profuel maybe any new insights? Thank you.
To the others - somebody around with a similar situation?
We are still encountering the same issue. Just another example is overwriting the rest validation yaml`s on store level. We have different rules, which are overwritten via the code buckets. We can not easily create tests to check if valueA is required in store DE and valueA is optional in sore EN, since store DE will be the default one in tests.
Thank you all.0
Categories
- All Categories
- 42 Getting Started & Guidelines
- 7 Getting Started in the Community
- 8 Additional Resources
- 7 Community Ideas and Feedback
- 78 Spryker News
- 935 Developer Corner
- 793 Spryker Development
- 90 Spryker Dev Environment
- 362 Spryker Releases
- 3 Oryx frontend framework
- 35 Propel ORM
- 68 Community Projects
- 3 Community Ideation Board
- 30 Hackathon
- 3 PHP Bridge
- 6 Gacela Project
- 26 Job Opportunities
- 3.2K 📜 Slack Archives
- 116 Academy
- 5 Business Users
- 370 Docker
- 551 Slack General
- 2K Help
- 75 Knowledge Sharing
- 6 Random Stuff
- 4 Code Testing
- 33 Product & Business Questions
- 69 Spryker Safari Questions
- 50 Random