TestUp is a wrapper on top of the minitest gem. It allow SketchUp Extension developers to write minitest
tests that runs within SketchUp.
- SketchUp 2017 or newer. (For SketchUp 2014-2016, use TestUp 2.4)
Easy: Download RBZ from the Releases tab on GitHub.
Latest: Install TestUp from git
source (See Setup for Contributing). Requires Node to build webdialog content before 2.3+ versions can be used.
Check out the wiki for details on creating tests. Make sure to also refer to minitest documentation.
Examples of extension projects implementing TestUp tests:
- https://bitbucket.org/thomthom/quadface-tools/src
- https://github.com/thomthom/shadow-texture/tree/dev-vscode-debug
TestUp require NodeJS to build webdialog resources: https://nodejs.org/en/ (Version 10.4 was used to build TestUp 2.3-2.5)
-
Fork the project to your own GitHub account. This is important so that we can do code review on changes done. Do not push directly to the main repository.
-
Clone your fork to your computer.
-
Open a command line at the project root:
npm install
npm run build
You can also use
npm run build -- --watch
to automatically rebuild whenever files changes. -
Add a helper Ruby file in your Plugins folder:
# load_testup.rb
# This adds the source directory to Ruby's search path and
# loads TestUp 2.
$LOAD_PATH << "C:/Users/YourUserName/Documents/testup-2/src"
require "testup.rb"
Optionally you can download a RBZ from the Releases tab on GitHub. Beware that this might not be always up to date. Setting up from git is recommended in order to easily keep up to date.
Follow the same steps as for "Setup for Contributing".
In order to load tests from our source code the paths where our tests are needs to be updated. This is done from the Preference dialog found under the TestUp dialog.
Click the gear symbol and you should see a list of paths. By default these will be pointing to the git repository's copy of our tests.
To package an RBZ from the content of the src
directory run:
(This assumes the binary libraries and webdialog resources have been built.)
npm run package
To build webdialogs and package in a single command:
npm run release
The RBZ appear in a generated archive
directory in the project root.
TestUp will log the details of a test-run. These can be found by using the menu
Extensions > TestUp > Open Log Folder
.
In there you will find .log
and .run
files.
The .log
files are for human reading, containing information about the
environment and what tests ran.
The .run
files are JSON files which can be used to re-play a test-run. From
the TestUp main dialog, click the Re-run...
button and select the .run
file
you are interested in. This will re-run the exact same tests with the same seed
so they are also run in the same order.
If you need to re-run a particular run several times you can use
Extensions > TestUp > Saved Runs > Add Run
. Then you can pick it from the
drop-down after choosing Extensions > TestUp > Saved Runs > Set Re-play Run
.
Windows:
"C:\Program Files\SketchUp\SketchUp 2023\SketchUp.exe" -RubyStartupArg "TestUp:CI:Path: C:\Users\Thomas\SourceTree\TestUp2\tests\TestUp UI Tests" > results.json
macOS:
'/Applications/SketchUp 2023/SketchUp.app/Contents/MacOS/sketchup' -RubyStartupArg 'TestUp:CI:Path: C:/Users/Thomas/SourceTree/TestUp2/tests/TestUp UI Tests' > results.json
In the example above TestUp will run a test suite given its path. The > results.json
will redirect the STDOUT to a file which will contain the JSON results of the test run.
# Config.yml
# Required:
Path: C:\Users\Thomas\SourceTree\TestUp2\tests\TestUp UI Tests
# Optional: (By default, don't include a fixed seed!)
Seed: 123 # The seed number for the random order of execution of the tests
# Optional:
# By default the results will be output to STDOUT. This can be redirected to a
# file.
Output: C:\Users\Thomas\SourceTree\TestUp2\tests\results.json
# Optional:
# Overriding where the .log files from a test run will be saved.
LogPath: C:\Users\Thomas\SourceTree\TestUp2\logs
# Optional:
# Path to a .log file that will be used if TestUp itself runs into any errors
# while running the tests.
ErrorLogPath: C:\Users\Thomas\SourceTree\TestUp2\testup_errors.log
# Optional:
# Overriding where the .run files from a test run will be saved.
SavedRunsPath: C:\Users\Thomas\SourceTree\TestUp2\logs
# Optional:
# Set to true to prevent SketchUp from closing. Useful for debugging purposes.
# Note that if `Output` is used the results won't be written until SketchUp is
# closed.
KeepOpen: false
# Optional:
# List the set of sets you want to run.
# Run all tests in test case: TC_TestCaseName#
# Run specific test: TC_TestCaseName#test_testname
Tests:
- TC_TestSamples#
- TC_TestErrors#test_pass
- TC_TestErrors#test_skip
Windows:
"C:\Program Files\SketchUp\SketchUp 2023\SketchUp.exe" -RubyStartupArg "TestUp:CI:Config: \Full\Path\To\Config.yml"
macOS:
'/Applications/SketchUp 2023/SketchUp.app/Contents/MacOS/sketchup' -RubyStartupArg 'TestUp:CI:Config: /Full/Path/To/Config.yml'
Expands to the directory where the configuration file is located.
Given a configuration file located at C:/Users/Thomas/SourceTree/TestUp2/testup-ui-ci.yaml
then %CONFIG_DIR%
will resolve to C:/Users/Thomas/SourceTree/TestUp2
.
# testup-ui-ci.yaml
Path: "%CONFIG_DIR%/tests/TestUp UI Tests"
Output: "%CONFIG_DIR%/tests/ui-tests-results.json"
tests = [
"TC_Sketchup_Model#test_active_section_planes.+",
]
path = "C:/src/testup-2/tests/SketchUp Ruby API/"
TestUp::API.run_tests(tests, path: path, options: { ui: false })
If you should get errors that relate to failing to install Minitest then you can attempt to install manually from a backup copy in this GitHub repository:
# From the SketchUp Ruby Console:
Gem.install('/path/to/repo/testup-2/gems/minitest-5.15.0.gem')
# Then restart SketchUp.
Thanks to Mark James for making his excellent icon set "Silk" available. Portions of the set is used in this project. Some file names has been renamed and some icons where mixed to create new status indicators for test result. http://www.famfamfam.com/lab/icons/silk/
The MIT License (MIT)
See the LICENSE file for details.