https://github.com/getdutchie/test_rail_dart
TestRail Dart API Wrapper
https://github.com/getdutchie/test_rail_dart
dart
Last synced: about 1 year ago
JSON representation
TestRail Dart API Wrapper
- Host: GitHub
- URL: https://github.com/getdutchie/test_rail_dart
- Owner: GetDutchie
- License: mit
- Created: 2021-10-13T01:59:54.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2022-04-03T22:49:46.000Z (about 4 years ago)
- Last Synced: 2025-03-27T23:04:26.931Z (about 1 year ago)
- Topics: dart
- Language: Dart
- Homepage:
- Size: 53.7 KB
- Stars: 3
- Watchers: 46
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README

# Test Rail Dart
This package is a thin wrapper around the TestRail API that will allow for automated test reporting in Dart. It enables a user to start, report case pass/fail, and close your test runs from a Dart interface.
## Getting Started
Initialize the TestRail instance using the config method:
```dart
TestRail.config(
username: 'USERNAME',
password: 'PASSWORD',
/// The url that points to the test rail server => https://example.testrail.com
serverDomain: 'https://YOUR_SERVER.testrail.com',
)
```
## Usage
### Create Test case
```dart
/// Create new test case in section
final createdTestCase = await TestCase.create(
// Replace with your own sectionId
1,
title: 'Test case from API',
customValues: {
// Custom fields start with "custom_" prefix
'custom_feedback': 'This case should be tested last',
},
);
```
### Delete Test case
```dart
/// Get TestCase by ID
final testCase = await TestCase.get(1);
await testCase.delete();
```
### Create or Update Runs
```dart
/// Start by creating a new run
final newRun = await TestRun.create(
name: 'Test execution',
projectId: 1,
);
/// Add cases to the run
await newRun.updateRun(
caseIds: [1, 2, 3, 5],
);
```
Once the run is created, results can be reported by case:
```dart
final result = await newRun.addResultForCase(
caseId: 1,
statusId: 1,
);
// Optionally add a screenshot or other image to the result
await result.addAttachment(
'/workspace/attachments/failure.png',
);
```
### Get
Historical runs, cases, and sections can be retrieved:
```dart
final testCase = await TestCase.get(1);
final testCases = await TestCase.getAll(1);
final testRun = await TestRun.get(1);
final testSection = await TestSection.get(1);
final testCaseHistory = await TestCaseHistory.get(1);
```
Completed or ongoing test run results can be retrieved:
```dart
final caseResults = await TestResult.getCaseResults(
// Case ID is from TestCases, not TestRun
184234,
runId: 1833,
);
final runResults = await TestResult.getRunResults(
1818,
statusId: [5, 1],
);
final testResults = await TestResult.getTestResults(
// Test ID from particular TestRun
1868150,
);
```
## About Dutchie
We’re not just building the future of shopping for cannabis, we’re building a culture of innovation, customer care, and challenge to the status quo.
Inspired? Join our team of [Dart and Flutter developers](https://dutchie.com/careers) today