graphql-to-karate
0.0.7
See the version list below for details.
dotnet tool install --global graphql-to-karate --version 0.0.7
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local graphql-to-karate --version 0.0.7
#tool dotnet:?package=graphql-to-karate&version=0.0.7
nuke :add-package graphql-to-karate --version 0.0.7
graphql-to-karate π
Project Status: Testing
π― About The Project
Automagically generate Karate API tests from your GraphQL schemas. Useful for test-driven development, change validation in CI/CD, and more.
β¨ Features
Here are some features that this tool provides:
- Generate API tests from GraphQL schemas: Karate API tests for both Query and Mutation operations are supported.
- Filterable Query and Mutation operations: Allows you to filter Query and Mutation operations so that you can generate tests for a specific subset of target operations.
- Validates response codes and response shapes: Validates response codes and uses Karate schema validation to ensure that the response shapes for each operation are valid.
- Supports all native GraphQL types: Supports
scalar
,object
,interface
,input
,enum
, andunion
GraphQL types. - Handles cyclical type relationships: Prunes cyclical types to remove cycles as they are encountered.
- Supports custom scalar types: Custom scalar types may be mapped to their corresponding Karate schema types.
- Supports union type validation: Each possible type within union types is validated against its corresponding expected schema.
- Generates test data for arguments and input types: Test data for query arguments and input types is generated automatically.
- Interactive and non-interactive CLI modes: Supports both interactive and non-interactive CLI modes, as well as JSON configuration.
See the full list of available options below for more information.
Installation
π₯ Binary Releases
Head over to releases and download the latest binary for your specific platform. If a binary for your platform is not available, see the Package Manager or Building From Source sections below.
π¦ Package Manager
graphql-to-karate
is also available as a NuGet offering and can be installed with the following command:
dotnet tool install --global graphql-to-karate --version 0.0.6
π¨ Building From Source
To build from source, clone the repository locally and run some flavor of the following command. Be sure to update <runtime identifier>
to your target platform. A catalog of available runtime identifiers can be viewed here.
dotnet publish src/GraphQLToKarate.CommandLine/GraphQLToKarate.CommandLine.csproj \
--configuration Release \
--runtime <runtime identifier> \
--output ./publish \
--self-contained true \
--force \
/p:PublishReadyToRun=true \
/p:PublishSingleFile=true \
/p:TreatWarningsAsErrors=false
Once published, you can move the binary to your preferred install location to use.
π οΈ Usage
To use graphql-to-karate
, simply invoke the graphql-to-karate convert
command, passing your GraphQL schema file as an argument:
graphql-to-karate convert my-schema.graphql
By default, you will be walked through conversion in an interactive way within the CLI.
A --non-interactive
option as well as JSON configuration are also available (see full Command Options below), which may be useful in CI/CD environments.
π Examples of Non-Interactive Invokation
Using Command-Line Options
graphql-to-karate convert my-schema.graphql \
--non-interactive \
--base-url "https://my-api.com" \
--custom-scalar-mapping DateTime:string,Long:number,Float:number,URL:string \
--query-operation-filter Users,UserById \
--output-file some-api.feature\
This flavor of graphql-to-karate
usage is used within CI/CD validation for this repository, where a mock GraphQL server is spun up, graphql-to-karate
converts the GraphQL schema to a Karate API test, and then the generated Karate API tests are run. Check it out here.
Using a JSON configuration
graphql-to-karate convert my-schema.graphql --non-interactive --configuration-file config.json
π Convert Command Options
OPTION | DEFAULT | ABOUT |
---|---|---|
-h, --help | Prints help information | |
--log-level | Information | Minimum level for logging |
--non-interactive | false | Whether to run conversion in a non-interactive way or not |
--output-file | graphql.feature | The output file to write the Karate feature to |
--query-name | Query | The name of the GraphQL query type |
--mutation-name | Mutation | The name of the GraphQL mutation type |
--exclude-queries | false | Whether to exclude queries from the Karate feature or not |
--include-mutations | false | Whether to include mutations in the Karate feature or not |
--base-url | "https://your-awesome-api.com" | The base URL to be used in the Karate feature |
--custom-scalar-mapping | The path or raw value custom scalar mapping | |
--query-operation-filter | A comma-separated list of GraphQL query operations to include in the Karate feature. If empty, all query operations will be included | |
--mutation-operation-filter | A comma-separated list of GraphQL mutation operations to include in the Karate feature. If empty, all mutation operations will be included | |
--type-filter | A comma-separated list of GraphQL types to include in the Karate feature. If empty, all types will be included | |
--configuration-file | The path of the configuration file |
πΊοΈ Roadmap
See the open issues for a list of proposed features (and known issues).
π€ Contributing
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated. For detailed contributing guidelines, please see the CONTRIBUTING docs.
π License
Distributed under the MIT License
License. See LICENSE
for more information.
Contact
Project Link: https://github.com/wbaldoumas/graphql-to-karate
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
This package has no dependencies.