The Python, Poetry, and Powershell requirements below can be installed with the help of the scripts in the eng directory. To isolate this Python environment to the repository, it's recommended to run the scripts from the repository's root.
./eng/install-test-runner-prerequisites.ps1
- Ed-Fi ODS/API Suite 3, version 5.x and 6.x
- ❗ Most recently, and most thoroughly, tested on 5.3. Versions 5.1 and 5.2 should be compatible, but have not been completely validated with the most recent changes to the testing toolkit.
- ❗ Most recently, tested on 6.2. Other Versions of 6.x
should be compatible, but have not been completely validated with the most
recent changes to the testing toolkit.
- ❕ The script automation assumes that the API is running in IIS, not Docker. If running with Docker or from Visual Studio, the tests will complete, but there may be an error at the end about inability to stop the World Wide Web Publishing Service. This can be ignored.
- Python 3.9+ (tested with 3.9.4)
- Poetry
- PowerShell 5.0+ to use the full toolkit, including metric collection from
Windows, IIS, and SQL Server.
- You may need to change your PowerShell security to allow running downloaded
scripts, for example with this command:
Set-ExecutionPolicy bypass -Scope CurrentUser -Force
. - Install the latest SqlServer module on the test host and the database server
- Install the Credential Manager module module on the test host.
- You might also need to configure TLS 1.2.
- Tested in: PowerShell 5.1 and PowerShell 7.2.
- You may need to change your PowerShell security to allow running downloaded
scripts, for example with this command:
- The user running the tests must be able to connect to the Web Server and the
Database Server with Windows authentication, with sys admin permissions in SQL
Server. You will be prompted to enter your credentials. This only applies
when using
run-tests.ps1
, which needs the user account for collecting metrics and (optionally) performing a database restore.
- Clone this repository using Git or download a Zip file for the 2.0 Paging Volume Tests release.
- Create a
.env
file in the root directory, based on.env.example
. Customize for your installation and testing requirements.- When
PERF_DB_RESTORE: True
is used, the toolkit will try to restore the database to a known good state using the specified backup file. The backup file path in the.env
file must be on the SQL Server.
- When
In the .env
file:
- To test all resources, comment out the
PERF_RESOURCE_LIST
entry. - For more information on the settings, see the edfi-paging-test README
From the root folder, simply call the run-tests.ps1
file while running in
Administrator mode.
./run-tests.ps1 -Type paging
Server metrics will be output to the ./TestResults/runner
directory. Paging
test results will be in a dated sub-directory, e.g.
./TestResults/YYYY-mm-dd-HH-MM-SS
.
These tests cover the resources that are used in the Ed-Fi SIS Certification program, and thus represent a broad swath of the most frequently used resources in the Ed-Fi community. There are three operational modes described below, with different run times and purposes.
The following settings are specific to the SIS Certification performance tests; please see edfi-performance-test for more information.
PERF_TEST_TYPE=change_query
PERF_DELETE_RESOURCES=true
PERF_FAIL_DELIBERATELY=false
CLIENT_COUNT=100
SPAWN_RATE=25
RUN_TIME_IN_MINUTES=30
PERF_API_PREFIX="/data/v3/ed-fi"
PERF_API_OAUTH_ENDPOINT="/oauth/token"
Valid PERF_TEST_TYPE
values are:
VOLUME
PIPECLEAN
CHANGE_QUERY
The PowerShell scripts provide several configuration modes with some default
settings that will override anything you have in the .env
file.
Output files will be placed into a date-and-time stamped sub-directory of the configured output directory.
Runs one client for about one minute, performing a simple set of CRUD operations on the available resources.
./run-tests.ps1 -Type pipeclean
Runs more complex data manipulations (create, update, and delete, with relatively few read calls) on the available resources. Runs for 30 minutes with 100 clients in parallel.
./run-tests.ps1 -Type volume
Executes the volume test suite, but ramping up the client count (and thus the number of requests) by 10-fold.
./run-tests.ps1 -Type stress
Executes the volume test suite, but ramping up the client count to 500 and running for 48 hours.
./run-tests.ps1 -Type soak
Executes GET requests using Change Queries on all resources, running for whatever length of time is specified in the config file, with only a single client.
./run-tests.ps1 -Type changequeries
- Double-check settings in the
.env
file. - Make sure the API is running and can be accessed from the machine running these tests.
- Make sure that the database is running, can be accessed from the machine running these tests, and supports integrated security.
- Confirm that the database backup conforms to the features and extensions in
the ODS/API code. For example, if the backup file was created from a database
that did not include change queries, then make sure the change queries feature
is disabled in the API project's
appsettings.json
file. Similarly, check that any extensions used by the API are actually installed in the database backup.