-
Notifications
You must be signed in to change notification settings - Fork 35
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
running integration tests #143
running integration tests #143
Conversation
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## development #143 +/- ##
============================================
Coverage 81.01% 81.01%
============================================
Files 46 46
Lines 4187 4187
Branches 1028 1028
============================================
Hits 3392 3392
Misses 763 763
Partials 32 32 ☔ View full report in Codecov by Sentry. |
I'd rather not start propagating KERIA dockerfiles to Signify client repos. Lets first get docker images published for KERA and reply on them in CI/CD for the clients otherwise we are going to have a mess of non-interoperable clients because they have their own "versions" of KERIA running. |
@pfeairheller There are no additional images built for this. They are built from keria, keripy and vLEI respectively, without any modifications. See docker-compose.yaml where images are specified. They are just hosted in my docker hub registry because the WebOfTrust registry was not updated. The idea is that it would be swapped for The reason I added an entrypoint.sh script, and mounted it in the container, is to be able to set configuration on startup. There should be another way to do this. This does not change the image, just the container at runtime. I will comment on the specific line. Edit: I have now removed the entrypoint.sh script and just specifying the entrypoint in the docker-compose file. This is probably less confusing. Ideally I would just be able to configure keria with environment variables or cli options to be able to run it inside a docker network. But at the moment I need to be able to set the hostname for keria within the docker network. Otherwise OOBI:ing won't work. |
a2859c2
to
8eb318e
Compare
I created and published the following docker images: WebOfTrust/keri-witness-demo:1.1.0 @lenkan can you please update your compose file and see if they all work for integration? Thanks! |
a9a2e93
to
e972f8f
Compare
Updated. It works 👍. I just used :latest for vlei and keria. Not sure what you think is the best strategy there. It is nice that it always pulls the latest stuff to ensure it works. But it can also cause a bit of a nuisance if keria upgrades and breaks integration tests for unrelated PRs at the client repo. |
I think getting the dev containers pushed on a regular basis will help us address this. So we can have dev builds use dev containers across the board and published versions rely on matching published versions. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good to me!
@lenkan , are we ready to merge this one, right? |
@rodolfomiranda It should be good to merge. I can help moving some of the remaining scripts to tests as well after this is merged. When KERIA images are being pushed on builds from KERIA repository with :latest tag, they will be picked up here. |
Here is a rough draft for creating and running integration tests in github actions.
The proposal is to move examples/integration-scripts one by one into thetest-integration
folder. We could just keep them as simple node.js script. But if we run them in a test runner we can get coverage reports, test results reporting and also group tests together more efficiently.Currently they depend on me pushing images to docker hub. But if we just start to push images from keripy, keria and vLEI on every commit we can just use the images from there. Another option (very slow) is to pull the source or python packages for each dependency and build them here before running the tests. But then we probably have to add some sort of image caching to make it run reasonably fast.The proposal is to rename the examples/integration-scripts with
.test.ts
suffix one-by-one. That way they will be picked up by the test runner.Currently, the images are being pulled from my docker hub registry. This is because the images in WebOfTrust were not up to date. Once they are, we can simply swap out for example
lenkan/keria
=>WebOfTrust/keria
in docker-compose.yaml.