Installation
Install with CLI
Recommended
gh skills-hub install scaffolding-oracle-to-postgres-migration-test-project Don't have the extension? Run gh extension install samueltauil/skills-hub first.
Download and extract to your repository:
.github/skills/scaffolding-oracle-to-postgres-migration-test-project/ Extract the ZIP to .github/skills/ in your repo. The folder name must match scaffolding-oracle-to-postgres-migration-test-project for Copilot to auto-discover it.
Skill Files (1)
SKILL.md 2.5 KB
---
name: scaffolding-oracle-to-postgres-migration-test-project
description: 'Scaffolds an xUnit integration test project for validating Oracle-to-PostgreSQL database migration behavior in .NET solutions. Creates the test project, transaction-rollback base class, and seed data manager. Use when setting up test infrastructure before writing migration integration tests, or when a test project is needed for Oracle-to-PostgreSQL validation.'
---
# Scaffolding an Integration Test Project for Oracle-to-PostgreSQL Migration
Creates a compilable, empty xUnit test project with transaction management and seed data infrastructure for a single target project. Run once per project before writing tests.
## Workflow
```
Progress:
- [ ] Step 1: Inspect the target project
- [ ] Step 2: Create the xUnit test project
- [ ] Step 3: Implement transaction-rollback base class
- [ ] Step 4: Implement seed data manager
- [ ] Step 5: Verify the project compiles
```
**Step 1: Inspect the target project**
Read the target project's `.csproj` to determine the .NET version and existing package references. Match these versions exactly โ do not upgrade.
**Step 2: Create the xUnit test project**
- Target the same .NET version as the application under test.
- Add NuGet packages for Oracle database connectivity and xUnit.
- Add a project reference to the target project only โ no other application projects.
- Add an `appsettings.json` configured for Oracle database connectivity.
**Step 3: Implement transaction-rollback base class**
- Create a base test class that opens a transaction before each test and rolls it back after.
- Catch and handle all exceptions to guarantee rollback.
- Make the pattern inheritable by all downstream test classes.
**Step 4: Implement seed data manager**
- Create a global seed manager for loading test data within the transaction scope.
- Do not commit seed data โ transactions roll back after each test.
- Do not use `TRUNCATE TABLE` โ preserve existing database data.
- Reuse existing seed files if available.
- Establish a naming convention for seed file location that downstream test creation will follow.
**Step 5: Verify the project compiles**
Build the test project and confirm it compiles with zero errors before finishing.
## Key Constraints
- Oracle is the golden behavior source โ scaffold for Oracle first.
- Keep to existing .NET and C# versions; do not introduce newer language or runtime features.
- Output is an empty test project with infrastructure only โ no test cases.
License (MIT)
View full license text
MIT License Copyright GitHub, Inc. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.