Generated project 
REQUIREMENTS
To run tests selectively with your generated project, use the tuist test command. The command
your Xcode project the same way it does for
warming the cache, and on success, it persists the hashes on to determine what has changed in future runs.In future runs tuist test transparently uses the hashes to filter down the tests to run only the ones that have changed since the last successful test run.
For example, assuming the following dependency graph:
- FeatureAhas tests- FeatureATests, and depends on- Core
- FeatureBhas tests- FeatureBTests, and depends on- Core
- Corehas tests- CoreTests
tuist test will behave as such:
| Action | Description | Internal state | 
|---|---|---|
| tuist testinvocation | Runs the tests in CoreTests,FeatureATests, andFeatureBTests | The hashes of FeatureATests,FeatureBTestsandCoreTestsare persisted | 
| FeatureAis updated | The developer modifies the code of a target | Same as before | 
| tuist testinvocation | Runs the tests in FeatureATestsbecause it hash has changed | The new hash of FeatureATestsis persisted | 
| Coreis updated | The developer modifies the code of a target | Same as before | 
| tuist testinvocation | Runs the tests in CoreTests,FeatureATests, andFeatureBTests | The new hash of FeatureATestsFeatureBTests, andCoreTestsare persisted | 
tuist test integrates directly with binary caching to use as many binaries from your local or remote storage to improve the build time when running your test suite. The combination of selective testing with binary caching can dramatically reduce the time it takes to run tests on your CI.
UI Tests 
Tuist supports selective testing of UI tests. However, Tuist needs to know the destination in advance. Only if you specify the destination parameter, Tuist will run the UI tests selectively, such as:
tuist test --device 'iPhone 14 Pro'
# or
tuist test -- -destination 'name=iPhone 14 Pro'
# or
tuist test -- -destination 'id=SIMULATOR_ID'