dart-test-fundamentals

Dart Test Fundamentals

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "dart-test-fundamentals" with this command: npx skills add kevmoo/dash_skills/kevmoo-dash-skills-dart-test-fundamentals

Dart Test Fundamentals

When to use this skill

Use this skill when:

  • Writing new test files.

  • Structuring test suites with group .

  • Configuring test execution via dart_test.yaml .

  • Understanding test lifecycle methods.

Discovery

To find candidates for improving test structure:

try-finally Cleanup

Search for tests that use try-finally for cleanup instead of addTearDown :

  • Regex: \bfinally\s*{ (Check if this is used for resource cleanup inside a test).

Core Concepts

  1. Test Structure (test and group )

test : The fundamental unit of testing.

test('description', () { // assertions });

group : Used to organize tests into logical blocks.

  • Groups can be nested.

  • Descriptions are concatenated (e.g., "Group Description Test Description").

  • Helps scope setUp and tearDown calls.

  • Naming: Use PascalCase for groups that correspond to a class name (e.g., group('MyClient', ...) ).

  • Avoid Single Groups: Do not wrap all tests in a file with a single group call if it's the only one.

  • NOTE: DO NOT remove groups when doing a cleanup on existing code you didn't create unless explicitly asked to. This can cause a LOT of churn in the DIFF that most engineers won't want!

Naming Tests test('test name here', :

  • Avoid redundant "test" prefixes. Use group instead.

  • Include the expected behavior or outcome in the description (e.g., 'throws StateError' or 'adds API key to URL' ).

  • Descriptions should read well when concatenated with their group name.

Named Parameters Placement:

  • For test and group calls, place named parameters (e.g., testOn , timeout , skip ) immediately after the description string, before the callback closure. This improves readability by keeping the test logic last. test('description', testOn: 'vm', () { // assertions });
  1. Lifecycle Methods (setUp , tearDown )
  • setUp : Runs before every test in the current group (and nested groups).

  • tearDown : Runs after every test in the current group .

  • setUpAll : Runs once before any test in the group.

  • tearDownAll : Runs once after all tests in the group.

Best Practice:

  • Use setUp for resetting state to ensure test isolation.

  • Avoid sharing mutable state between tests without resetting it.

  1. Cleaning Up Resources
  • To clean up resources created WITHIN the test body, consider using addTearDown instead of a try-finally block.

Avoid:

test('can create and delete a file', () { final file = File('temp.txt'); try { file.writeAsStringSync('hello'); expect(file.readAsStringSync(), 'hello'); } finally { if (file.existsSync()) file.deleteSync(); } });

Prefer:

test('can create and delete a file', () { final file = File('temp.txt'); // Register teardown immediately after resource creation intent addTearDown(() { if (file.existsSync()) file.deleteSync(); });

file.writeAsStringSync('hello'); expect(file.readAsStringSync(), 'hello'); });

  1. Configuration (dart_test.yaml )

The dart_test.yaml file configures the test runner. Common configurations include:

Platforms

Define where tests run (vm, chrome, node).

platforms:

  • vm
  • chrome

Tags

Categorize tests to run specific subsets.

tags: integration: timeout: 2x

Usage in code:

@Tags(['integration']) import 'package:test/test.dart';

Running tags: dart test --tags integration

Timeouts

Set default timeouts for tests.

timeouts: 2x # Double the default timeout

  1. File Naming
  • Test files must end in _test.dart to be picked up by the test runner.

  • Place tests in the test/ directory.

Common commands

  • dart test : Run all tests.

  • dart test test/path/to/file_test.dart : Run a specific file.

  • dart test --name "substring" : Run tests matching a description.

Related Skills

dart-test-fundamentals is the core skill for structuring and configuring tests. For writing assertions within those tests, refer to:

  • dart-matcher-best-practices: Use this if the project sticks with the traditional package:matcher (expect calls).

  • dart-checks-migration: Use this if the project is migrating to the modern package:checks (check calls).

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

dart-best-practices

No summary provided by upstream source.

Repository SourceNeeds Review
556-kevmoo
General

Wundervault Vault

Read passwords, API keys, and credentials from a Wundervault encrypted secret vault, and run vault-authorized shell commands with secrets injected — without...

Registry SourceRecently Updated
General

public-media-curator

On-demand German public-media documentary picks filtered against a personal profile, sent via Telegram

Registry SourceRecently Updated
General

Education Search 教育学习搜索助手

学历教育与职业培训找资料工具。学历教育包括考研(公共课/专业课真题)、专升本、自考等;职业培训包括考公(行测/申论)、教师资格证、经济师、建造师、会计师、法律职业资格等。支持三种类型:找试题试卷、找教辅资料、找备考课程。当用户需要查找考试相关资料时使用此 skill。

Registry SourceRecently Updated