-
Notifications
You must be signed in to change notification settings - Fork 563
[Help Wanted] Add Test Suite Toolchain #25
Comments
Hi there I may be interested in helping out but would like to get a little more details on expected outcomes =) Like are we looking for a suite of Unit + Integration tests? Does the test-suite have to test the plugins itself or does the suite just have to test that they are loaded correctly? What about first party plugins? Are those expected to have more in depth tests as well? Thanks! |
Right now, the test suite should run the existing tests so it can be put into automation. Ideally each plugin would have their own unit tests and we’d have a comprehensive suite of integration tests but that is a longer term goal |
The expected outcomes for today are: Most of that can be referenced from the ci pipeline for the main repo |
Okay great! I didn't realize there were tests in place already. I'm pretty comfortable with GH Actions and ive setup these types of workflows before at my day job so I'll take a peek at the ci pipeline for the main repo and see if this is something I can commit to =) |
ive been super pre-occupied catching up with the tech and playing with all the plugins, I should have a chance to look over this on the weekend |
Hey @ntindle I created #123 that adds the CI from the main repo here. I can see the GH actions run fine on my fork h4ck3rk3y#3 but I think it hides them for me in the PR as I am not admin. Would love to help with the integration testing piece! What are you thinking with that? What about spinning up AutoGPT, loading the plugin giving it some prompts and seeing if it responds as expected? Or is it enough to test that the latest image continues to load with the plugin? |
The power of open source :)! |
I was thinking similar lines. Spin up autogpt with plugins and an assert there are no errors on start Then maybe start adding basic "smoke" tests that runs an example command from each plugin to make sure the plug-in isn't completely borked? Over time I suspect the more intricate unit/integration test cases come from the authors of the plugins themselves? |
Hey @BaseInfinity @ntindle to keep the conversation going - Here's an example of a nightly run that checks whether the plugin loads as expected; it tests it for three different plugins (but all of them have the same zip) Here's the code for it https://github.com/kurtosis-tech/autogpt-package/blob/main/.circleci/config.yml#L41-L69 Would you be open to a similar GH action on this repo? |
Yes, in GHA and we need a time to talk about the install method. Really would love cross (all) platform support though. Is it on the roadmap? |
You were very prompt to respond! Hey @ntindle Kurtosis runs on Linux, MacOS and Windows(via WSL)! Does that work for you? Or do you want native Windows support? We have it on the roadmap but haven't prioritized it yet as we haven't seen much demand for a Windows native client. Is Windows support a blocker for a GitHub Action that does the integration test? Here are the installation instructions. |
It's a blocker for being a recommend install method for the whole project but not for actions. Sorry for being unclear |
That makes sense; I'll explore how quickly we can get to a native Windows client! In the meantime I'll try to send you a GHA PR to spin up & test plugin installations. |
Hey @ntindle! We started to publish a native Windows binary that does not require WSL! We updated the documentation here https://docs.kurtosis.com/next/install/ |
I haven't used Kurtosis myself but I'm wondering what the advantage of using something like that versus using a prebaked image for the OS we want: I'm always a fan of using as many tools that GH provides when choosing to work with GHA for compatibility/stability. I'm also open to Kurtosis, like with any other tool I just want to make sure I understand what the advantages of it are =) |
@BaseInfinity You can run Kurtosis on top of the pre baked images like in this PR #131 Think of Kurtosis as a powerful alternative to Python + Bash + Docker Compose. If you have Kurtosis installed on your system you can have AutoGPT running against the latest stable image published by AutoGPT with a lot of plugins supported out of the box This snippet here runs AutoGPT with the Twitter Plugin and then gives you the terminal you are accustomed too;
This snippet here runs AutoGPT with the Email Plugin & Redis (spinning up an instance for you) and then gives you the terminal you are accustomed too;
This snippet here runs AutoGPT with the AutoGPTApiTools plugin & Weaviate (spinning up an instance for you) and then gives you the terminal you are accustomed too;
Note you didn't have to download any plugin, Kurtosis did it for you. Note you didn't have to spin up Redis or Weaviate up yourself, Kurtosis did it for you! You can use remote PineCone as well or remote Milvus! |
@ntindle As Victor said we are available as a native windows executable now too!
We're working on supporting a local(inside Docker) version of Milvus; we support all first party plugins but are adding support for more third party plugins; trying to get to parity with the README on this repository. Also; I am more than happy transferring the |
Kurtosis sounds neat but seems like it's very new tech with little less than 50 stars on Github....I'm worried about its lifespan and installing something that very few people know about I'm open minded but it's not my call, maybe @ntindle can tag someone from the main GH Repo who's familiar with their current CI implementation and see if this is something they want to adopt? Not trying to be negative, it's just my reaction anytime I see new tech and choosing it as a foundation....been bit way too many times. Also I think it's fair to point out that you guys work for Kurtosis so you guys have a bias lol, much different than two passionate developers pushing a tech you enjoy =) |
I'm pretty familiar with the CI of the main repo as I did the base of a large portion of it. Will look at this further later but we have a huge issue with install problems and a small team that will fix problems we have directly is almost always better than a big one who won't |
Very good point, love that thinking Just wanted to play devil's advocate myself, I'm sure whatever we adopt will be fine for our needs, i've just gotten very paranoid over the years lol To Kurtosis' credit, they are open source |
@h4ck3rk3y lets wait till 0.4.0 comes out as install process might change significantly |
Love the discussion here @BaseInfinity! We made our code available on GitHub primarily to reduce anxiety that you have; we want our code to be available if we are long gone so our users can keep using us. Sounds good @ntindle I'll be on the look for the new version 👍 |
haha I'm glad this is an inviting discussion, it warms my heart when there's more than 1 person passionate about testing in a repo =) I'll spend some time looking at the Kurtosis docs and maybe implement it in a simple project of mine to learn about it more. Thanks for not getting offended lol. If anything you two have proved @ntindle point of being swift and more connected than a bigger box name would be so im on board (not that anyone needed me to be, im new here lol) Looking forward to seeing this built out and helping out where i can |
Thanks for the kind words @BaseInfinity! I hope you enjoy the tool; would love to learn how you felt using it. |
@ntindle Hey! Just checking in - Do we know by when 0.4.0 will be out?! An update from our side - last week someone on my team added arg validation to autogpt-package; so it validates that all plugin args are set before the package is run! Optionally you can skip validation if you want :-) |
No |
Hey! We have added support for 0.4.0 here https://github.com/kurtosis-tech/autogpt-package If someone for some reason wants to run against 0.3.1 they just have to
Plugins etc still work! Let us know if you have any next steps for us :) |
We need to add a test suite toolchain for code stability
The text was updated successfully, but these errors were encountered: