ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

Test Switcher

by davidmreed ST3

A Sublime Text extension to move between source and test files easily.

Labels testing

Details

Installs

  • Total 122
  • Win 35
  • Mac 59
  • Linux 28
Apr 26 Apr 25 Apr 24 Apr 23 Apr 22 Apr 21 Apr 20 Apr 19 Apr 18 Apr 17 Apr 16 Apr 15 Apr 14 Apr 13 Apr 12 Apr 11 Apr 10 Apr 9 Apr 8 Apr 7 Apr 6 Apr 5 Apr 4 Apr 3 Apr 2 Apr 1 Mar 31 Mar 30 Mar 29 Mar 28 Mar 27 Mar 26 Mar 25 Mar 24 Mar 23 Mar 22 Mar 21 Mar 20 Mar 19 Mar 18 Mar 17 Mar 16 Mar 15 Mar 14 Mar 13
Windows 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Mac 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
Linux 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

Test Switcher for Sublime Text

© 2017 David Reed, distributed under the MIT License.

This plugin provides a configurable way to swap between source files and corresponding test classes in Sublime Text 3. Invoke it while viewing a source file to tab to the corresponding test file, or vice versa, by choosing Test Switcher from the command palette or pressing Control-Shift-Insert (Linux and Windows) or Command-Shift-\ (Mac). Test Switcher scans open tabs first for matching files and then walks the directory tree for your open folders.

The plugin can be configured to find tests using many different naming conventions. It matches on basename (file name minus extension) as well as on extension. To configure basename matching, in the plugin's settings, supply a list for prefixes and suffixes. These will be added to the source file base name to locate possible test class files, and will be matched against the head and tail of open files to locate the source files corresponding to tests. The default configuration looks for prefixes ["test", "test_"] and suffixes ["test", "_test", ".spec"]. Hence, a source file named Base.py would match to a test file named TestBase.py, Test_Base.py, Base_test.py, BaseTest.py, or Base.spec.py, and vice versa. Note that matching is case-insensitive on all platforms.

You may also, if you choose, supply test_extensions and source_extensions. If present, only test and source files who match according to the defined name rubric and possess an extension in the relevant list will be offered as an option. If the lists are blank or empty, extensions are ignored.