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

Better approach to manage pre-existing Accounts and Node parameters #333

Merged
merged 66 commits into from
Sep 12, 2024

Conversation

jernst
Copy link
Member

@jernst jernst commented Sep 11, 2024

The primary goal of these changes are to create a uniform way to specify pre-existing accounts on the nodes referenced in a TestPlan. This may be necessary because:

  • a given app at a Node does not have an API by which accounts can be automatically provisioned
  • ... or the code to do so hasn't been written, such as when developers only start to use FediTest with their app
  • or the developer may want to re-run the same tests with the same accounts that already exist on an instance they are running themselves as "SaaS"
  • or the developer may want to re-run the same tests, getting the exact same user names even if they are auto-provisioned, to make debugging easier.

There are several difficulties:

  • Each application may need different data to identify an existing account. For example, some may need username and password, others e-mail address and OAuth token etc.
  • Communicating what is needed for a given situation / app to the developer is really hard; nobody likes to pour through long documentation (which we probably couldn't keep up-to-date and testing that a given version is up-to-date would be a challenge in itself). This would -- and has for me -- led to significant frustration: "I'm specifying all these things, why isn't it working?"
  • Error checking code will be all over the place. Consistent error checking and reporting is not really possible without a lot of repeat code review work.
  • Different tests may require a different (and potentially unlimited) number of accounts. The approach should seamlessly scale to a number larger than the pre-existing accounts, by auto-provisioning new accounts or asking the user to do so.

A similar situation applies to non-existing-accounts: similar to accounts, it identifies what could be an account, but is known not to exist. This is required for things such as WebFinger tests against non-existing accounts.

While migrating the ad-hoc mechanisms we had in the code for specifying pre-existing accounts, I also implemented a similar mechanism for Node parameters: what parameters are required or supported on a given Node was not obvious.

Example that illustrates the point (needs better formatting but you get the point):

% feditest info --nodedriver MastodonSaasNodeDriver
Node driver name:             MastodonSaasNodeDriver
Description:                  Create a Mastodon Node that already runs as SaaS
Parameters:                   {'app': 'Name of the app', 'app_version': 'Version of the app', 'hostname': 'DNS hostname of where the app is running.', 'verify_api_tls_certificate': 'If set to false, accessing the Mastodon API will be performed without checking TLS certificates.'}
Account fields:               {'userid': 'Mastodon userid for a user (e.g. "joe") (required).', 'email': 'E-mail for the user on an Account. Required for accounts specified with a password (not a token) because logging into Mastodon is by e-mail address.', 'password': 'Password for a user. Required for accounts that also have an e-mail address and no token.', 'oauth_token': 'OAuth token of a user, obtained out of band, for users not specified with e-mail address and password.', 'role': 'A symbolic name for the Account as used by tests (optional).'}
Non-existing Account fields:  {'userid': 'Mastodon userid for a non-existing user (e.g. "joe")  (required).', 'role': 'A symbolic name for the non-existing Account as used by tests (optional).'}

In implementation terms, the key changes are:

  • a NodeConfiguration object which does all the parameter checking, default settings etc as early as possible so TestPlans with invalid parameters fail long before they try to actually run. This means we don't pass a parameter dict around any more, but a config object that, when it exists, is known to be internally consistent.
  • An AccountManager object associated with each Node. Different implementations implement different strategies for how to return requested accounts and/or when and how to provision new ones. While feditest could conceivably be applied to Nodes that run software that do not have the notion of an account, that seems very unusual and isn't worth making things more complicated; AccountManager could simply be ignored in that case.
  • Information about pre-existing Accounts and Parameters are captured, including their name, description and error checking code in TestPlanNodeAccountField, TestPlanNodeNonExistingAccountField and TestPlanNodeParameter.
  • There are several feditest TestPlans that run against the Mastodon API. Not all of them run yet, but some do.

Johannes Ernst added 30 commits August 16, 2024 14:55
Work in progress: user records and non-existing users for Mastodon and WordPress
Add check methods
Add uri field to ExistingAccount and NonExistingAccount
…fication in the TestPlans, they can pull accounts out directly
Created InteractiveFallbackFediveseAccountManager that can be pre-seeded with known accounts/non-accounts in the TestPlan, and interactively asks for more when needed
Node Account and NonExistingAccount objects get a .node attribute to the Node they belong to
Keep the AccountManager out of the NodeConfiguration after all -- dynamically changing sets of Accounts (indirectly) inside a NodeConfiguration feels wrong
Create the AccountManager and NodeConfiguration at the same time in the same factory method, however
Parameters and accounts may have null values in Testplan
Migrate use of parameters to UbosNodeConfig
Johannes Ernst added 17 commits September 8, 2024 17:27
…: the larger the numbers get, the more they tests, assuming that earlier tests did a good job reporting on smaller units to test
…les certificate checking when mastodon.py accesses the Mastodon API

Distinguish between None and boolean-false-equivalent values in parameter()
add boolean_parse_validate()
…xception instead

use float for time delays as in python time.sleep()
More comments in test
… Currently does not work yet, instance B cannot find the user on instance A. Needs debugging.
Rename method to avoid Node vs NodeDriver confusion.
Added FediTest TestPlan for WordPress. Not working yet though.
@jernst jernst requested a review from steve-bate September 11, 2024 00:31
Copy link
Member

@steve-bate steve-bate left a comment

Choose a reason for hiding this comment

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

Like you mentioned, it's difficult to review such a large set of commits. As a developer, for the 'info --nodedriver' output, I'd prefer formatted JSON rather than the long single-line text. Should the pyunit subdirectory be pytest or maybe just unit (vs the feditest integration test subdirectory)? For the rest of the changes, I'll just need to catch up after the smoke clears a bit.

@steve-bate
Copy link
Member

How do I run the tests in the feditest/tests/feditests directory?

@jernst Can you remove the tests/mastodon_parameters.json file. There was an example file with placeholders for hosts/etc., but this one must have been accidentally committed at some point. It's not a huge security concern because that server is only started temporarily for testing purposes, but I'd still like to clean it up (especially if we don't plan to use the test_mastodon_node.py unit tests). Now that we have the pre-commit support, I'll be sure to add a NOCOMMIT to any future local configurations.

@jernst jernst merged commit c4111b1 into fediverse-devnet:develop Sep 12, 2024
1 check passed
@jernst
Copy link
Member Author

jernst commented Sep 12, 2024

To run the tests in tests/feditests:

feditest run --testsdir tests/feditest --testplan tests/feditests/mastodon_saas_api.json

or such. Once we have #191, the user should be able to specify a testplan template that doesn't have a node specification in it, and their particular node specification as a separate JSON file. Then, that node specification can be defined locally once, and reused in all of the test runs without having to change the test plan template.

@jernst jernst deleted the pr-add-accounts-to-node branch September 17, 2024 00:01
jernst added a commit that referenced this pull request Oct 24, 2024
* [WIP] Experimental Mastodon API Node (#178)

* Experimental (PoC) version of Mastodon API Node

* Changed time.sleep to use retry_interval

* Support for Mastodon node test

* Guarded import kludge

* Mastodon API node mixin (#209)

* Updated pyproject.toml per #208. Not sure I got this right -- we will find out when we push.
Also added note about bugs.

* Release HOWTO (#234)

* Draft for release howto

* As I've worked with this list for today's release, obviously it turned out to have many bugs. This is better.

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Minor lint improvement (#242)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Minor formatting improvement (#244)

Co-authored-by: Johannes Ernst <git@j12t.org>

* All NodeDrivers are now singletons. (#241)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Add ssh support for ubos-admin commands so we can drive UbosNodes that are on remote servers (#243)

* Add ssh support for ubos-admin commands so we can drive UbosNodes that run on remote servers.

* UbosNodeDriver now unprovisions, no need to do this in the WordPressPlusActivityPubPluginUbosNodeDriver
Also, the WordPress Node does not depend on UBOS; renamed

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Allow overriding PYTHON executable path (#236)

* Allow overriding PYTHON executable path

* Allow overriding other configuration variables

---------

Co-authored-by: Matthew Exon <git.mexon@spamgourmet.com>

* Better error message if python cannot be found per #236 (comment) (#245)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Using create- and generate- prefixes in the CLI commands is confusing. Let's only use create- (#246)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Add some tests (#248)

* Move some things around to make test setup easier (isolate @test etc annotation functionality)
Allows to remove env var workaround for selective nodedriver loading
Adding some tests

* .gitignore

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Instead of limiting invoking ubos-admin over ssh, we can make it a general-purpose mechanism that also works for mechanisms like "machinectl shell" or ssh with non-standard flags. (#249)

Co-authored-by: Johannes Ernst <git@j12t.org>

* More appname as parameter changes (#251)

* More appname as parameter changes and related

* Lint improvements

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Added fake node driver. (#258)

Skip tests if no mastodon config is present.

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Memoise previous responses to prompt for account URIs (#260)

Co-authored-by: Matthew Exon <git.mexon@spamgourmet.com>

* Checking for empty test result list. (#267)

Transcript won't be written in this case.

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Command to list report templates (#265)

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Make it possible to do http_get/http requests with TLS cert verification. (#268)

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Updated --template name and help. (#266)

Added diagnostics for missing HTML templates.

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Feditest side of http support changes (#269)

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Update nodedriver decorator (#272)

1. Add return type annotation (helps with IDE)
2. Return the annotated type (so import works)

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Customize pytest collection to ignore feditest objects. (#274)

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Get UbosNodeDriver to generate its own SIte JSON files instead of hard coding them (#252)

One thing led to another, and this got a bit long ... there are still some rough edges but I feel it's better to merge now before this gets even further out of hand. Major changes:

    manual NodeDriver registration for built-in NodeDrivers
    Transcript version check
    our own private certificate authority, integrated with system trust store on UBOS and venv everywhere
    more consistent handling of Node parameters and parameter completions
    MastodonMixin has become a NodeWithMastodonAPI, which in turn is a subclass of FediverseNode. This makes things simpler including parameter handling and Node/NodeDriver implementations
    Automated user provisioning for Mastodon on UBOS, works consistently for ActivityPub Actors and WebFinger accounts
    No more need for the restore-from-backup hack for WordPress because we now use wp-cli to fix the permalink scheme at run-time
    Facade mechanism for ActivityStreams objects based on underlying JSON -- this may be a good compromise between typed / untyped and invalid data
    Clarified the semantics of some of the Node API calls in the comments and adjusted code accordingly
    always use rolename, not nickname
    Generate UBOS Site JSON dynamically with new ids, certs, hostnames instead of hard coding -- the original purpose of this branch.

Caveats:

    Recursive AS Collection resolution is untested, and needs its own tests because it's so complicated
    UBOS packages mastodon, wordpress need to be manually rebuilt, and wp-cli manually installed from Arch (updates are not in the UBOS repos yet)

* Fix cast syntax. Fixes #279.

* Use @DataClass. Fixes #278

* UserId to ActorURI mapping both directions for WordPress. Fixes #275 and #283.

* Fix httpx invocation. Fixes #288

* Don't use _member for @DataClass per feedback

* Use httpx.Response.raise_for_status() -- no need to invent our own exceptions

* Fix TypeVar definition. (#297)

Closes #295

Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>

* Fix ZeroDivision when converting test transcript with no tests to HTML. Fixes #298.

* Don't try to write Registry CA info to disk if we haven't used it in a run. Fixes #299.

* Missed two occurrences of _userid in earlier PR

* Use dict.get if key may not exist.

* Clean up parser vs sub-parser in CLI commands, closes #294.

* Create pytest that tests we report on NodeDriver errors. Closes #188

* Alias for --json: --testresult

* Fixed error with unsupported delete_on_close keyword arg (#305)

* Renamed TestException (#306)

* Add built-in noopN tests -- makes debugging node provisioning easier
Load default NodeDrivers and default tests first, so local setup can override them

* Use a better exception for ubos-admin errors

* Fix development of feditest to python version 3.11, so we don't get unexpected surprises when somebody runs it on debian or such. Fixes #307. (#309)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Default version without installed package. (#314)

* Replaced '== None' with 'is None' (flagged by ruff linter) (#315)

* Fixed clashing field and function name (#316)

* Initial pre-commit support. (#313)

* Initial pre-commit support.

* Updated hook versions. Added pytest src config.

* Enabled NOCOMMIT check

* Pass TestPlanConstellationNode to Node, so it can directly look up things
Node._parameters are now only local overrides

* Make the random domain a bit longer (#317)

Better name for our custom CA
Add x509 SubjectAlternativeName to cert: apparently python ssl needs it
Added types-requests dependency to make mypy happy
Mastodon.py can now create the OAuth app using our custom CA

Co-authored-by: Johannes Ernst <git@j12t.org>

* Add mypy to pre-commit. Fix a few small issues. (#321)

* Enabled pre-commit hook for ruff linting (#319)

* Added pytest hook. (#322)

Disabled test_mastodon_node temporarily until it is passing again.
Also updated mypy to autoinstall type libraries.

* Second attempt at making the WebFinger query API call consistent

* Keep the Node parameters private to the Node and NodeDriver, which gets to pull them from the TestPlan if it wants to
Also pass the test_plan_node to Node._fill_in_parameters()
start_delay() is now an official property

* White space

* More white space

* Now all parameters are back on Node, no need to delegate to _test_plan_node

* The Node subclasses actually don't really need the TestPlanConstellationNode. They may need the pre-provisioned user tables, but it's up to the specific implementation of Node and its NodeDriver to provide those suitably. So not in the superclass.

* GitHub workflow for PR/pre-commit

* Fix failing unit test.

* Better approach to manage pre-existing Accounts and Node parameters (#333)

The primary goal of these changes are to create a uniform way to specify pre-existing accounts on the nodes referenced in a TestPlan. This may be necessary because:

* a given app at a Node does not have an API by which accounts can be automatically provisioned
* ... or the code to do so hasn't been written, such as when developers only start to use FediTest with their app
* or the developer may want to re-run the same tests with the same accounts that already exist on an instance they are running themselves as "SaaS"
* or the developer may want to re-run the same tests, getting the exact same user names even if they are auto-provisioned, to make debugging easier.

There are several difficulties:

* Each application may need different data to identify an existing account. For example, some may need username and password, others e-mail address and OAuth token etc.
* Communicating what is needed for a given situation / app to the developer is really hard; nobody likes to pour through long documentation (which we probably couldn't keep up-to-date and testing that a given version is up-to-date would be a challenge in itself). This would -- and has for me -- led to significant frustration: "I'm specifying all these things, why isn't it working?"
* Error checking code will be all over the place. Consistent error checking and reporting is not really possible without a lot of repeat code review work.
* Different tests may require a different (and potentially unlimited) number of accounts. The approach should seamlessly scale to a number larger than the pre-existing accounts, by auto-provisioning new accounts or asking the user to do so.

A similar situation applies to non-existing-accounts: similar to accounts, it identifies what could be an account, but is known not to exist. This is required for things such as WebFinger tests against non-existing accounts.

While migrating the ad-hoc mechanisms we had in the code for specifying pre-existing accounts, I also implemented a similar mechanism for Node parameters: what parameters are required or supported on a given Node was not obvious.

Example that illustrates the point (needs better formatting but you get the point):

```
% feditest info --nodedriver MastodonSaasNodeDriver
Node driver name:             MastodonSaasNodeDriver
Description:                  Create a Mastodon Node that already runs as SaaS
Parameters:                   {'app': 'Name of the app', 'app_version': 'Version of the app', 'hostname': 'DNS hostname of where the app is running.', 'verify_api_tls_certificate': 'If set to false, accessing the Mastodon API will be performed without checking TLS certificates.'}
Account fields:               {'userid': 'Mastodon userid for a user (e.g. "joe") (required).', 'email': 'E-mail for the user on an Account. Required for accounts specified with a password (not a token) because logging into Mastodon is by e-mail address.', 'password': 'Password for a user. Required for accounts that also have an e-mail address and no token.', 'oauth_token': 'OAuth token of a user, obtained out of band, for users not specified with e-mail address and password.', 'role': 'A symbolic name for the Account as used by tests (optional).'}
Non-existing Account fields:  {'userid': 'Mastodon userid for a non-existing user (e.g. "joe")  (required).', 'role': 'A symbolic name for the non-existing Account as used by tests (optional).'}
```

In implementation terms, the key changes are:
* a `NodeConfiguration` object which does all the parameter checking, default settings etc as early as possible so TestPlans with invalid parameters fail long before they try to actually run. This means we don't pass a `parameter` dict around any more, but a config object that, when it exists, is known to be internally consistent.
* An `AccountManager` object associated with each Node. Different implementations implement different strategies for how to return requested accounts and/or when and how to provision new ones. While feditest could conceivably be applied to Nodes that run software that do not have the notion of an account, that seems very unusual and isn't worth making things more complicated; `AccountManager` could simply be ignored in that case.
* Information about pre-existing Accounts and Parameters are captured, including their name, description and error checking code in `TestPlanNodeAccountField`, `TestPlanNodeNonExistingAccountField` and `TestPlanNodeParameter`.
* There are several feditest TestPlans that run against the Mastodon API. Not all of them run yet, but some do.

* This solves my mystery ruff problem where ruff would complain about ExceptionGroup not existing, although I'm running python 3.11. Why I need it and others don't IDK. (#336)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Ignore exceptions that occur when we discover tests or nodedrivers, e.g. Skip from pyunit tests that happen to be in the browsed directories (#339)

Co-authored-by: Johannes Ernst <git@j12t.org>

* The plan with the global registry variable failed badly: run --domain did not work. Redesign to use accessor functions. (#341)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Use new UBOS `allow_private_addresses` customizationpoint on Mastodon and make test work (#344)

* Use new UBOS `allow_private_addresses` customizationpoint on Mastodon so Mastodon will not block HTTP requests on the local network, which we need for testing purposes

* Fix the mastodon-against-mastodon unit test -- works now in interactive mode (too fast in non-interactive mode)
In Mastodon, need to poll local and remote time line
Start delay for Mastodon should be 10
Better log messages

* Make ruff happy

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Move unit tests directory. (#348)

* Move unit tests directory.
Closes #337

* Remove test_mastodon_node.py
Closes #308

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Fix confusion of whether role_names are before or after rolemapping: better name of function: needed_constellation_role_names, fixes role mapping issue (#352)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Better followers api on FediverseNode (#349)

* Minor

* Create a utility function that replaces next() -- and works better with my brain :-)

* Better API calls on FediverseNode that deal with followers. Closes #346
Cannot check generically for arrival of ActivityPub messages in inbox; need specific methods so it can map on things like the Mastodon API
Also fixes race condition when running mastodon_mastodon_ubos.json in automated mode

* Fix test sequence so that follower receives the leader's note

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* A few odds and ends (#351)

* Clean up some property messiness that caused test failures

* Print Field names, not Fields directly in interactive questions

* Now that we have settled on python3.11, we might as well put it into the Makefile: works on macOS with brew and on Linux/UBOS

* Adjust unit tests for moved role parameter in FallbackFediverse{,NonExisting}Account

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Support testing direct messages (via @mention) in Mastodon (#354)

* Return the content of the received Note
Fix mention generation in Mastodon
Notes delivered through mention (not follow) in Mastodon arrive in notifications, not home timeline
* Mastodon API .notifications() and .timeline() return different data structures, apparently. Handle both.
* Remove comment that's distracting in the stack trace

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* mypy setup improvements (#356)

* Add more surgical disable comment into the source to disable certain mypy checks
* Make Makefile-invoked mypy options consistent with those in .pre-commit-config.yaml
* Bump mypy version
---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Make progress on WordPress+ActivityPubPlugin. Not working yet. (#355)

* Make progress on WordPress+ActivityPubPlugin. Not working yet.
WordPress needs to have its own Account implementation -- different path than Mastodon
Added OAuth token account provisioning code from Enable_Mastodon_Apps developer
Throw Exception if mastodon_user_client was about to return None

* Move _mastodon_user_client variable down in inheritance hierarchy, hopefully that will make mypy happy

* Trailing slash for WordPress author URLs. Fixes #292

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Added methods to support fediverse-devnet/feditest-tests-fediverse#141 (#359)

Clarify some comments.

Co-authored-by: Johannes Ernst <git@j12t.org>

* Allow registry to generate certs for hostnames specified in the TestPlan as well (#360)

Better Node toString

Co-authored-by: Johannes Ernst <git@j12t.org>

* Allow "run" to be invoked with session and constellation arguments, not just full test plan (#362)

* Allow specification of the components of a testplan as an alternative to the --testplan in the run command.
* Fixes #191 well enough, not sure we need to do this for the other commands
* Use ArgumentError for CLI invocation errors, not fatal
* Move feditest unit tests into their own tests directory; makes invocation easier
* Instead of having test plans in the feditest unit test directory, have constellations and session templates: much better for usability
* Add more noop tests
* Don't add built-in noop tests to test sessions created from looking on disk what tests we can find
* Print needed role names when "feditest info --test <name>"
* add --test option to "feditest run" so we can specify which tests to run directly from the command-line

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Fix test issue #148 (#366)

* Fixes for testing replies fediverse-devnet/feditest-tests-fediverse#148
* Slight changes in parameter names and internal function names for more clarity
* Remove Mastodon status_dict cache: it introduces potential errors and race conditions that we would have to work through
* Better, more consistent debug messages

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Always approve and confirm automatically provisioned Mastodon users (#365)

Do not use uppercase characters in Mastodon user ids -- they are not accepted in the API

Co-authored-by: Johannes Ernst <git@j12t.org>

* WordPress working except for the SSRF problem (#368)

* Disable mastodon.py's version check for WordPress -- it cannot parse the version string
* Random OAuth token for WordPress
* Fix Mastodon userid regex
* In NodeWithMastodonAPI, distinguish between userid (the handle) and internal_userid (an integer); the latter is needed in Mastodon API calls
* In NodeWithMastodonAPI, use @Property and _property
* Don't allow all punctuation chars for auto-generated passwords
* Activate mastodon.py debug_requests when trace logging is active
* Add WordPress friends plugin by default on UBOS
* Better error messages when Node parameter fields or user attributes are missing or invalid
* Better logging and exceptions
* Lint improvement

Closes #284
Closes #285

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Use tests.unit and tests.smoke instead of tests.unit/*/ (#369)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Work around WordPress SSRF protection (#371)

* Use new UBOS WordPress customizationpoint `disablessrfprotection`.
* Record ubos-admin error messages
* Closes #367
* Fix name of the node we are logging into, copy-paste error
* Uncomment wait_until_actor_is_follow* calls in smoke test; however, fails with WordPress due to #370.

Co-authored-by: Johannes Ernst <git@j12t.org>

* Make CLI arguments consistent (#372)

* Use argparse action='append' consistently, not nargs='*' except when enumerating tests on the command-line
* Create cli.util to factor out ways to create TestPlan components from command-line options
* Make arguments to the various cli command consistent, and use the same code to parse them where applicable

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Move "internal" tests from feditest-tests-sandbox repo and make them proper unit tests (#373)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Use the correct test name. (#375)

Closes #374

Co-authored-by: Johannes Ernst <git@j12t.org>

* Remove the default testplan argument value from run.

Co-authored-by: Johannes Ernst <git@j12t.org>

* Rename WordPress Driver  (#378)

* Closes #377

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Clean up package hierarchy (#381)

* Move feditest/ubos/__init__.py to feditest/nodedrivers/ubos.py -- better location
* Move Node, NodeDriver and associated classes from feditest.protocols to feditest.nodedrivers -- much more logical location
* Fix \ missing escape in PHP string
* Add smoke tests to Makefile

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Move prompt_user() into utils.py, there hasn't been good reason for some time for this to be on Node / NodeDriver. (#382)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Reflect the difference between protocol-level and system-level functionality in the code (#383)

* Split methods on Node subtypes between regular Nodes and Nodes with diagnostic abilities (like the Imp)
* Factor out functionality from Imp that is useful in other WebFingerDiagClients -> AbstractWebFingerDiagClient
* Two exceptions are WebFinger-related not Web-related: move
* Make diag_override_http_response implementation consistent with turning on HTTP request logging
* Be clear that FediTest does not itself fetch ActivityPub documents, it only asks other Nodes to do it
* Better documentation and comments
* Comment-out some currently inconsistent code; get back to it with ActivityPub tests
* Make the sequence of class definitions in files Client, Server, not Server, Client: it's called client-server after all, not server-client.

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Some minor cleanup (#384)

* ParsedUri should have a get_scheme() method
* Fix WordPress app name
* Better comments
* Add a --domain flag to the run invocations in the Makefile
---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Migrate the Fediverse protocol API to use acct identifiers, not Actor URIs (#385)

* Use `acct` URIs instead of `https` Actor URIs to drive the protocols/fediverse API. This allows us to get around a limitation in the WordPress / Enable Mastodon Apps implementation of search (cannot search for Actor URI)
* This also allows us to simplify how many subtypes of Account we need.
* This also allows us the user to only specify an `acct` URI for existing accounts, and not both `acct` and Actor `https`, which was cumbersome.
* Cleaned up smart factory methods in `NodeWithMastodonAPI` to more easily get right, instead of more easily get wrong :-P
* Query the Mastodon API by `acct`, not `id` -- the WordPress implementation has same behavior with `acct`, but not with `id` as the WordPress federated users aren't first-class users in WordPress.
* Last smoke test (WordPress against Mastodon) is now working

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Add WebFinger smoke tests (#386)

* Add WebFinger smoke tests
* In smoke tests, use node.json files instead of constellation.json files: fewer files, more flexibility
* Run WordPress smoke tests first: they run faster

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Rename feditest/cli/util.py -> feditest/cli/utils.py to be consistent with other utils.py

* Emit warning if submodule loading failed, not just trace

* Fix type annotations for @test and @step

* Use @Property for the elements of ParsedUri and subclasses
Use parsed_uri instead of uri member variable on Request -- easier to understand

* Fix regex escape

* Implement missing mapping from WebFingerServer obtain_xxx_account_identifier to AccountManager in FallbackFediverseNode

* Remove saas node definitions from smoke tests with pre-set values

* Fix bad implementation of set_auto_accept_follow on FediverseNode (#389)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Remove wait_util_* methods from FediverseNode. Replace by utils' poll_until() and exposing the underlying polled functions. This simplifies things.
Split prompt_user into two functions, which can have more sane / lint-friendly signature and allows us to remove a bunch of cast()'s

* Add feditest.disabled for easy commenting out of tests

* Remove use of the mastodon.py library: its benefits are marginal, but it gets in the way of straightforward debugging. (#391)

Co-authored-by: Johannes Ernst <git@j12t.org>

* Remove TimeoutException, instead raise an AssertionFailure when a poll_until rimes out
Move poll_until into fediverse main package from utils
Add poll_but_not as the opposite function

* Add -i to run as shorthand for --interactive

* Add FediverseNode.note_has_direct_reply

* Also add accept header to our Mastodon API invocations
All Mastodon API call HTTP headers are now lowercase
Mastodon API debug output also shows JSON responses

* Fix UBOS-only smoke tests

* Make --interactive input more visible when -v -v mode is on

* Remove branch component of the venv part; not as useful as originally thought

* Yet another regex escape fix

* Fix embarrassing mixup between session index and step index when asking for the next step in a test run

* Add methods access_note and update_note to FediverseNode
Better Mastodon API debug output in case of errors

* Clean up FediverseNode API

Reorder methods on FediverseNode for better comprehensibility (#395)
Add some FediverseNode methods for next set of tests
Rename account_id_*validate to acct_uri_*validate for consistency
Add list-of validation functions

Co-authored-by: Johannes Ernst <git@j12t.org>

* Fix so received boosts are correctly detected in Mastodon.

* Add FediverseNode methods unlike_object and unannounce_object

* Simplify TestRun id

* Generated TestPlanSession ignores --name argument

* CSS and other small HTML report improvements
Add duration to test steps in report

* Make emitted timestamps consistent

* HTML escape payload from error messages. Closes #392

* Fix NullPointerExceptions

* Typo

* Use action=append instead of nargs=+ for --test argument.
Closes #402

* Add python version check. Closes #405.

* Re-imagine TestPlan as a single TestPlanSessionTemplate that is run against one or more Constellations (#407)

* That makes it consistent with how we generate HTML matrix reports.
* TestPlanSession so now is more correctly called TestPlanSessionTemplate
* Generate a single HTML file for single-Constellation TestPlans, and N+1 HTML files for N-Constellation TestPlans
* Reorganize Serializers and jinja2 templates
* Update unit tests
* Lint improvements

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

* Get ready for 0.4 (#408)

* Fix minor version comparison
* feditest version to only print the version, so it can be used in git checkout
* Consistent description of the project
* Update project version
* Make HTML report titles and H1's consistent
* Minor CSS
* Now called session_template not session; update Jinja2 template
* Better formatting of SpecLevel and InteropLevel in HTML
* To trigger CORS headers, the Origin header sent from the client must have a URI method
* Rename WebFingerQueryResponse -> WebFingerQueryDiagResponse
* Simplify multiple exceptions in WebFingerQueryDiagResponse
* Simplify ignoring exceptions of certain types in WebFinger tests so each test doesn't report other tests' exceptions
* Updating RELEASE-HOWTO

---------

Co-authored-by: Johannes Ernst <git@j12t.org>

---------

Co-authored-by: Steve Bate <steve-bate@users.noreply.github.com>
Co-authored-by: Johannes Ernst <git@j12t.org>
Co-authored-by: Matthew Exon <github2.mexon@neverbox.com>
Co-authored-by: Matthew Exon <git.mexon@spamgourmet.com>
Co-authored-by: Steve Bate <svc-atlassian@stevebate.net>
Co-authored-by: Steve Bate <svc-github@stevebate.net>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants