Our review
Provides a structured guide for creating, updating, or removing Mason bricks, including template files, tests, and CI workflow integration.
Strengths
- Covers the complete lifecycle of a Mason brick (create, update, delete).
- Includes test setup and CI workflow to ensure brick reliability.
- Uses Mustache helpers (snakeCase, pascalCase, etc.) for flexible templates.
- Clear folder structure and step-by-step instructions reduce errors.
Limitations
- Assumes familiarity with Dart, Mason, and GitHub Actions.
- Does not cover advanced hook usage or multi-brick coordination.
- CI example is specific to Flutter/Dart; may need adaptation for other ecosystems.
When you need to create or maintain a reusable code generation template in a Dart/Flutter project using Mason.
When you only need a one-off code scaffold without tests or CI, or if you're not using Dart/Flutter.
Security analysis
SafeThe skill is a development guide for Mason bricks, containing no malicious instructions, obfuscated code, or dangerous commands that would be automatically executed. It uses standard shell commands (mkdir, rm, dart) in the context of development workflows, which are typical and not inherently risky when used as described. No exfiltration, privilege escalation, or disabling of safety systems is instructed.
No concerns found
Examples
I need to create a new Mason brick called 'feature' that generates a Flutter feature folder with model, view, and controller files. Include tests and CI workflow.Update the existing 'widget' brick to add an optional 'with_bloc' variable that conditionally includes a Bloc class.Remove the 'deprecated' brick from the project, including its test and CI job.name: template-mason-brick description: Guide for creating, updating, or removing Mason bricks with corresponding tests and CI workflow (project)
Mason Brick Development Skill
This skill guides the creation, modification, and removal of Mason bricks, ensuring test coverage and CI workflow integration.
When to Use
Trigger this skill when:
- Creating a new Mason brick template
- Updating an existing brick's structure or variables
- Removing a brick from the project
- User asks to "create a brick", "add a mason template", "update brick", or "remove brick"
Project Structure
Bricks are organized in three locations:
bricks/ # Mason template definitions
├── brick_name/
│ ├── brick.yaml # Brick configuration and variables
│ ├── __brick__/ # Template files with Mustache syntax
│ └── hooks/ # Optional pre/post generation hooks
test_bricks/ # Brick tests (one folder per brick)
├── brick_name/
│ └── brick_name_test.dart
.github/workflows/
└── brick-test.yml # Parallel CI jobs for each brick
Creating a New Brick
Step 1: Create Brick Directory
mkdir -p bricks/new_brick/__brick__
Step 2: Create brick.yaml
name: new_brick
description: Description of what this brick generates
version: 0.1.0+1
environment:
mason: ^0.1.1
vars:
name:
type: string
description: The name for the generated component
prompt: What is the name?
# Add more variables as needed
optional_var:
type: boolean
description: Optional feature flag
default: true
Step 3: Create Template Files
In __brick__/, create files using Mustache syntax:
__brick__/
├── {{name.snakeCase()}}/
│ ├── lib/
│ │ └── {{name.snakeCase()}}.dart
│ ├── pubspec.yaml
│ └── README.md
Use these Mustache helpers:
{{name}}- raw value{{name.snakeCase()}}- snake_case{{name.pascalCase()}}- PascalCase{{name.camelCase()}}- camelCase{{name.paramCase()}}- param-case{{#flag}}...{{/flag}}- conditional block{{^flag}}...{{/flag}}- inverted conditional
Step 4: Create Brick Test
Create test_bricks/new_brick/new_brick_test.dart:
import 'dart:io';
import 'package:mason/mason.dart';
import 'package:path/path.dart' as path;
import 'package:test/test.dart';
void main() {
group('New Brick Tests', () {
late Directory tempDir;
setUp(() async {
tempDir = await Directory.systemTemp.createTemp('new_brick_test_');
});
tearDown(() async {
if (await tempDir.exists()) {
await tempDir.delete(recursive: true);
}
});
test('generates correct structure', () async {
final brick = Brick.path(path.join('..', '..', 'bricks', 'new_brick'));
final generator = await MasonGenerator.fromBrick(brick);
await generator.generate(
DirectoryGeneratorTarget(tempDir),
vars: {'name': 'test_name'},
);
// Verify generated files exist
final file = File(path.join(tempDir.path, 'test_name', 'pubspec.yaml'));
expect(await file.exists(), isTrue);
});
// Add more tests for different variable combinations
});
}
Step 5: Add Workflow Job
Add a new job to .github/workflows/brick-test.yml:
new-brick:
name: Test new_brick
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v6
- uses: flutter-actions/setup-flutter@v4
- name: Cache dependencies
uses: actions/cache@v5
with:
path: |
~/.pub-cache
.dart_tool
key: ${{ runner.os }}-pub-${{ hashFiles('**/pubspec.lock') }}
restore-keys: ${{ runner.os }}-pub-
- name: Install tools
run: dart pub global activate melos
- name: Prepare project
run: |
melos run prepare
mason get
- name: Test new_brick brick
run: dart run test_bricks/new_brick/new_brick_test.dart
Step 6: Register Brick
Add to root mason.yaml:
bricks:
new_brick:
path: bricks/new_brick
Then run mason get to register.
Updating an Existing Brick
When modifying a brick:
- Update
brick.yamlif adding/removing variables - Update template files in
__brick__/ - Update tests in
test_bricks/brick_name/to cover changes - Run test locally:
dart run test_bricks/brick_name/brick_name_test.dart - Increment version in
brick.yaml
Removing a Brick
When removing a brick, update all three locations:
- Remove brick directory:
rm -rf bricks/brick_name - Remove test directory:
rm -rf test_bricks/brick_name - Remove workflow job from
.github/workflows/brick-test.yml - Remove from
mason.yaml - Update CLAUDE.md if the brick was documented
Testing Locally
# Register bricks
mason get
# Test a specific brick
dart run test_bricks/brick_name/brick_name_test.dart
# Test brick generation manually
mason make brick_name -o /tmp/test_output --var1=value1
Existing Bricks Reference
| Brick | Purpose | Key Variables |
|-------|---------|---------------|
| screen | Flutter screen with routing | name, folder, has_adaptive_scaffold |
| widget | Reusable widget | name, type, folder |
| simple_bloc | Basic BLoC package | name |
| list_bloc | List management BLoC | name |
| form_bloc | Form validation BLoC | name, field_names |
| repository | Data repository | name |
| api_client | API client package | package_name |
| native_federation_plugin | Federated native plugin | name, package_prefix, support_* |
Checklist
When creating/updating a brick:
- [ ]
brick.yamlhas name, description, version, and vars - [ ] Template files use correct Mustache syntax
- [ ] Test file exists in
test_bricks/brick_name/ - [ ] Tests cover main generation paths
- [ ] Workflow job added/updated in
brick-test.yml - [ ] Brick registered in
mason.yaml - [ ] Run
mason getto verify registration - [ ] Run test locally before committing
Next.js App Router Expert
Development
A skill that turns Claude into a Next.js App Router expert.
README Generator
Development
Creates professional and comprehensive README.md files for your projects.
API Documentation Writer
Development
Generates comprehensive API documentation in OpenAPI/Swagger format.