Skip to content
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

Add plugin support. #941

Merged
merged 6 commits into from
Nov 27, 2020
Merged

Add plugin support. #941

merged 6 commits into from
Nov 27, 2020

Conversation

valkum
Copy link
Contributor

@valkum valkum commented Aug 26, 2020

This PR adds support for plugins in sytest. The bootstrap script will download given plugins and sytest will use them.

You can now pass the env var $PLUGIN with the format PLUGINS="<owner>/<repo>[:<owner>/<repo>]"
bootstrap.sh (when downloading sytest) will load <owner>/<repo> from github to /sytest/plugins/<owner>/<repo>
and will look if a matching runner script is found in one of the plugins.

Example:

$ PLUGIN="valkum/conduit_sytest" bootstrap.sh "conduit"
$ # Downloads https://github.com/valkum/conduit_sytest to /sytest/plugins/valkum/sytest 
$ # and executes /sytest/plugins/valkum/sytest/scrypts/conduit_sytest.sh

Sytest will look for Output and ServerImplementation plugins in the plugin dir.
Plugin dir is /sytest/plugin by default but can be overwritten by the env var $SYTEST_PLUGINS

@clokep
Copy link
Member

clokep commented Aug 27, 2020

@valkum Were you hoping for feedback on this or does it need more work (noting that this is a draft PR)?

@valkum
Copy link
Contributor Author

valkum commented Aug 27, 2020

@valkum Were you hoping for feedback on this or does it need more work (noting that this is a draft PR)?

The SyTest part is tested, but I could not test the bootstrap.sh part in a container yet because of failing builds for the base image. Mentioned that in the homerserver-dev matrix room.
Wanted to get some feedback before I invest more time into testing.

So this needs both: Work and Feedback :)

run-tests.pl Outdated Show resolved Hide resolved
@valkum valkum force-pushed the feature-plugins branch 3 times, most recently from 7dc1617 to e61a412 Compare September 17, 2020 12:24
bootstrap.sh will now download plugins given in the env var PLUGIN
The format is <repo>/<plugin> and only github is support for now.
They get downloaded into /sytest/plugins by default.
Multiple plugins can be given, devided by : (similar to PATH)

SyTest will now look for plugins in /sytest/plugins (overridable by $SYTEST_PLUGINS)
ServerImplementations and Output plugins are supported for now.
The dir structure of plugins follows the structure of sytest itself.

See http://github.com/valkum/sytest_conduit for an example plugin
@valkum
Copy link
Contributor Author

valkum commented Sep 17, 2020

I finished the missing work and tested it locally. Ready for review

@valkum valkum marked this pull request as ready for review September 17, 2020 12:28
@clokep clokep requested a review from a team September 17, 2020 13:43
@anoadragon453
Copy link
Member

Could you give us an understanding of what the usecase for plugins in Sytest would be? I took a look at https://github.com/valkum/sytest_conduit, and it seems add files to allow SyTest to spin up and run against a Conduit instance.

Could you not instead simply PR those files to this repo to add support instead?

@valkum
Copy link
Contributor Author

valkum commented Sep 23, 2020

Submitting a PR for Conduit would be another way. But depending on how many Homeserver implementations will get created over time I thought this would be a better way.
With plugin support different projects are able to add their own Homeserver implementations and Output formatters.

If you are more interested in simply adding Conduit support to SyTest its fine. I would submit a PR with our Homeserver implementation then.

Copy link
Member

@richvdh richvdh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this is generally a nice approach. I've left a few comments on details of it.

Generally: as part of the work, please make sure the documentation is updated to match. In particular, I think the top-level README and https://github.com/matrix-org/sytest/blob/develop/docker/README.md will need an update to document the new features, and the expected layout of the plugins directory/archives.

run-tests.pl Outdated Show resolved Hide resolved
run-tests.pl Show resolved Hide resolved
docker/bootstrap.sh Outdated Show resolved Hide resolved
docker/bootstrap.sh Outdated Show resolved Hide resolved
if [ -n "$PLUGIN" ]; then
mkdir /sytest/plugins
echo "--- Downloading plugins for sytest"
IFS=':'; for plugin in $PLUGIN; do
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should probably be called PLUGINS, if it's going to support more than one plugin?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah. I thought of the PATH var while writing it not sure why that is not called PATHS, but PLUGINS makes more sense. Will change that.

docker/bootstrap.sh Outdated Show resolved Hide resolved
echo "--- Downloading plugins for sytest"
IFS=':'; for plugin in $PLUGIN; do
wget -q https://github.com/$plugin/archive/master.tar.gz -O plugin.tar.gz || {
echo "Failed to download plugin: $plugin"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we write this (to stdout rather than stderr) and then carry on with mkdir and tar anyway? seems like we should exit instead? or just let set -e handle it?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for finding this. Yeah we should exit there with sending the msg to stderr.

@valkum
Copy link
Contributor Author

valkum commented Sep 24, 2020

I answered some of your feedback. I will add documentation when we decided on the exact format of dirs and variables.

@anoadragon453 anoadragon453 requested a review from richvdh October 7, 2020 15:05
@richvdh
Copy link
Member

richvdh commented Oct 12, 2020

@valkum are you still interested in working on this?

@richvdh richvdh removed their request for review October 12, 2020 15:07
@richvdh richvdh added the X-Awaiting-Changes A contributed PR which needs changes and re-review before it can be merged label Oct 12, 2020
@valkum
Copy link
Contributor Author

valkum commented Oct 12, 2020

Yeah, wrote kegsay in the complement room that I am currently at crunchtime and can pick up work on this (and the one in complement) after the 26th.

Remove github tie in.
Plugins can be tar.gz files hosted anywhere now.
Added README info.
@richvdh richvdh self-requested a review November 19, 2020 10:52
Copy link
Member

@richvdh richvdh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

looks good, though the docs could do with a few tweaks.

thanks!

docker/bootstrap.sh Show resolved Hide resolved
README.rst Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
@richvdh richvdh requested a review from a team November 22, 2020 16:29
README.rst Outdated Show resolved Hide resolved
README.rst Outdated Show resolved Hide resolved
Copy link
Member

@richvdh richvdh left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lgtm! thanks very much!

@richvdh
Copy link
Member

richvdh commented Nov 27, 2020

right, one remaining thing to do: please could you read https://github.com/matrix-org/synapse/blob/master/CONTRIBUTING.md#sign-off and add a comment below with a "signed-off-by" line, to confirm you agree to the statement there?

@richvdh
Copy link
Member

richvdh commented Nov 27, 2020

[CI failed due to matrix-org/synapse#8785, which is fixed in #984)

@valkum
Copy link
Contributor Author

valkum commented Nov 27, 2020

signed-off-by: Rudi Floren rudi.floren@gmail.com

@richvdh richvdh merged commit 86f3ed8 into matrix-org:develop Nov 27, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
X-Awaiting-Changes A contributed PR which needs changes and re-review before it can be merged
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants