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
565-kevmoo
General

Huo15 Openclaw Wechat Service

OpenClaw 微信服务号(公众号)渠道插件 v2.2.0 —— 新增**角色权限系统**:permissionMode='role-based' 支持 superadmin/admin/editor/operator/customer 五级角色,自由配置 rolePermissions 白名单;**AI 对话...

Registry SourceRecently Updated
General

AIWolfPK - AI狼人杀

四个AI互相猜疑,你坐着看戏。每局30秒,到底谁是狼? Four AIs play Werewolf while you watch. 30s per round. Spot the wolf before they do.

Registry SourceRecently Updated
General

Hot Content Creator

热点内容创作助手:自动抓取多平台热点,筛选创作方向,生成小红书封面图和虚拟博主形象, 写出有人味的爆款内容。触发词:热点创作、追热点、创作方向、小红书方向、抖音方向。 适用场景:需要从热点中挖掘内容创作方向并生成配图+文案的完整工作流。

Registry SourceRecently Updated