From 51f865045578d656a44fb8cb1408d4d8ffc8dd50 Mon Sep 17 00:00:00 2001 From: Robert Oostenveld Date: Wed, 17 Jan 2024 11:07:03 +0100 Subject: [PATCH] some rewording, fixed formatting of a note --- development/releasing.md | 16 ++++++++-------- development/testing.md | 12 +++++------- 2 files changed, 13 insertions(+), 15 deletions(-) diff --git a/development/releasing.md b/development/releasing.md index a102133ff..e4ee87dcc 100644 --- a/development/releasing.md +++ b/development/releasing.md @@ -9,7 +9,11 @@ redirect_from: Daily releases of FieldTrip are made available on the download server. The corresponding commits (i.e., point in time in the git repository) are tagged, such that the releases are also [available from GitHub](https://github.com/fieldtrip/fieldtrip/releases). New FieldTrip versions are released only if all tests pass. So, on some days there will not be a release. -## Quality control in FieldTrip +## Releasing the code + +Every evening one of the FieldTrip [automation scripts](https://github.com/fieldtrip/automation) is executed as a cron job. It checks whether there are new commits on the [release branch](https://github.com/fieldtrip/fieldtrip/tree/release), and if so, it makes a new zip file of fieldtrip, fieldtrip-lite, and some of the modules, and copies those to the download server. It also tags the corresponding commit on the release branch on GitHub with ""YYYYMMDD", consistent with the naming of the zip files. + +## Quality control prior to every release The [fieldtrip/test](https://github.com/fieldtrip/fieldtrip/tree/master/test) directory contains many test scripts (technically they are functions). We use these initially to reproduce and identifying the cause of a bug, or for designing new end-user scripts that matches some new functionality that we want to implement. Once a reported bug has been fixed and/or the new functionality has been implemented, we keep the test scripts for [regression testing](https://en.wikipedia.org/wiki/Regression_testing). @@ -19,14 +23,10 @@ If you suspect a problem with the FieldTrip code, the best way to resolve it is The [master branch](https://github.com/fieldtrip/fieldtrip/tree/master) is tested _every evening_ by executing all test functions using the [dashboard scripts](https://github.com/fieldtrip/dashboard) that are running as a cron job on the [DCCN compute cluster](https://dccn-hpc-wiki.readthedocs.io). If the complete test batch passes, the changes on the master branch are automatically merged into the [release branch](https://github.com/fieldtrip/fieldtrip/tree/release). If there is a problems with one of the test scripts, an email is sent to the main developers and the updates are _not_ merged from master into release. -## Releasing the code - -Every evening one of the FieldTrip [automation scripts](https://github.com/fieldtrip/automation) is executed as a cron job. It checks whether there are new commits on the [release branch](https://github.com/fieldtrip/fieldtrip/tree/release), and if so, it makes a new zip file of fieldtrip, fieldtrip-lite, and some of the modules, and copies those to the download server. It also tags the corresponding commit on the release branch on GitHub with ""YYYYMMDD", consistent with the naming of the zip files. - -## Testing guidelines to external contributors +## Guidelines to contributors -{% include markup/end %} -When you [contribute](/development/contribute) to FieldTrip, it is recommended that you [test your changes](/development/testing). If the necessary test scripts pass, you can submit a [pull request](https://github.com/fieldtrip/fieldtrip/pulls). {% include markup/info %} +When you [contribute](/development/contribute) to FieldTrip, it is recommended that you [test your changes](/development/testing). If the necessary test scripts pass, you can submit a [pull request](https://github.com/fieldtrip/fieldtrip/pulls). +{% include markup/end %} When you [add a new FieldTrip function](/development/testing#adding-a-new-test-script), it is good practice to also include a short test script. This helps the maintainers to evaluate your contribution, and in the future to ensure that future changes to code elsewhere do not break your contribution. When you [modify existing code](/development/testing), you should check for existing [test scripts](/development/testing#running-existing-tests) and run them locally prior to sending a pull-request. diff --git a/development/testing.md b/development/testing.md index 3edbf0ef1..4ac3abdc3 100644 --- a/development/testing.md +++ b/development/testing.md @@ -7,11 +7,9 @@ redirect_from: # Testing -## Why is testing important? +To make sure everything works correctly, we use [regression testing](https://en.wikipedia.org/wiki/Regression_testing). This way, we can be confident that when we add, modify, or remove a function, we won't break the existing ones. Testing also helps us find and fix any issues early on, ensuring that FieldTrip functions smoothly for all users. We use nightly testing as part of the [release](/development/releasing) procedure. -FieldTrip is a toolbox with many functions, designed to be compatible with each other. This means that one function often relies on the output of another function. Functions are categorized as [high, low-level, or private](https://www.fieldtriptoolbox.org/development/architecture/#high-level-low-level-and-private-functions), with high-level functions depending on low-level and private functions. - -To make sure everything works correctly, we use [regression testing](https://en.wikipedia.org/wiki/Regression_testing). This way, we can be confident that when we add, modify, or remove a function, we won't break the existing ones. Testing also helps us find and fix any issues early on, ensuring that FieldTrip functions smoothly for all users. We use nightly testing as part of the [release](/development/release) procedure. +FieldTrip is a toolbox with many functions, designed to be compatible with each other. This means that one function often relies on the output of another function. Functions are categorized as [high, low-level, or private](https://www.fieldtriptoolbox.org/development/architecture/#high-level-low-level-and-private-functions), with high-level functions depending on low-level and private functions. The regression testing mainly focusses on high- and low-level functions that users can call from their analysis scripts. ## How are the tests organized in FieldTrip? @@ -56,7 +54,7 @@ This helps to select an appropriate subset of tests to run based on: 1. **WALLTIME**: The duration that a test needs to run. This duration is usually more than the actual duration needed since it also includes the time that MATLAB itself takes to start (which is about 30-60 seconds) and the time that it takes to load the test data. 2. **MEM**: MEM stands for memory, and it represents the amount of memory required for a test to run. 3. **DATA**: The external data that the test requires to run. More specifically, `DATA no` means that the test doesn't need any external data to run. `DATA public` means it needs data available from the [download server](https://download.fieldtriptoolbox.org/). `DATA private` means that it needs data that are not publicly accessible but only to people working in the DCCN. -4. **DEPENDENCY**: The dependencies, i.e. high- or low-level FieldTrip functions to which the test script is particularly sensitive. There are three types of dependencies within the FieldTrip codebase: self-dependencies (where a function relies on itself), direct dependencies (comprising both [high-level and some low-level FieldTrip functions](https://www.fieldtriptoolbox.org/development/architecture/#high-level-low-level-and-private-functions) called directly within a test script), and indirect dependencies (involving [some low-level functions and all the private FieldTrip functions](https://www.fieldtriptoolbox.org/development/architecture/#high-level-low-level-and-private-functions) that, while they are not directly called within a test script, still play a role in the execution process). For example, in FieldTrip you can run: +4. **DEPENDENCY**: The dependencies, i.e. high- or low-level FieldTrip functions to which the test script is particularly sensitive. There are three types of dependencies within the FieldTrip codebase: self-dependencies (where a function relies on itself), direct dependencies (comprising both [high-level and some low-level FieldTrip functions](https://www.fieldtriptoolbox.org/development/architecture/#high-level-low-level-and-private-functions) called directly within a test script), and indirect dependencies (involving [some low-level functions and all the private FieldTrip functions](https://www.fieldtriptoolbox.org/development/architecture/#high-level-low-level-and-private-functions) that, while they are not directly called within a test script, still play a role in the execution process). For example, in FieldTrip you can run: ft_test find_dependency test_bug46 @@ -131,8 +129,8 @@ If you are an external contributor outside the DCCN network, you can select test To quickly find potential errors, you may want to run the short and small tests first. You can sort the tests with increasing memory and walltime: - % Convert the memory from string to numbers to allow sorting. - filtered_test.mem = str2double(filtered_test.mem); + % Convert the memory from string to numbers to allow sorting. + filtered_test.mem = str2double(filtered_test.mem); filtered_test = sortrows(filtered_test, 'mem', 'ascend'); filtered_test = sortrows(filtered_test, 'walltime', 'ascend');