3 unstable releases

0.2.0 Jul 16, 2024
0.1.1 Feb 6, 2024
0.1.0 Jan 25, 2024

#554 in Database interfaces

Download history 16/week @ 2024-07-21 39/week @ 2024-07-28 102/week @ 2024-08-04 72/week @ 2024-08-11 82/week @ 2024-08-18 155/week @ 2024-08-25 178/week @ 2024-09-01 140/week @ 2024-09-08 152/week @ 2024-09-15 124/week @ 2024-09-22 125/week @ 2024-09-29 130/week @ 2024-10-06 117/week @ 2024-10-13 241/week @ 2024-10-20 93/week @ 2024-10-27 105/week @ 2024-11-03

572 downloads per month

Apache-2.0

27KB
484 lines

graphql-schema-diff

crates.io] docs.rs

This crate implements diffing of two GraphQL schemas, returning a list of changes. It powers the changelog feature and operation checks at Grafbase.

Example

use graphql_schema_diff::{diff, Change, ChangeKind};

let source = r#"
  type Pizza {
    id: ID!
    name: String!
    toppings: [Topping!]!
  }

  enum Topping {
    OLIVES
    MUSHROOMS
    PINEAPPLE
  }
"#;

let target = r#"
  type Pizza {
    id: ID!
    name: PizzaName
    toppings: [Topping!]!
  }

  type PizzaName {
    english: String
    italian: String!
  }

  enum Topping {
    OLIVES
    MUSHROOMS
    POTATO
  }
"#;

let changes = diff(source, target).unwrap();

assert_eq!(changes,
   &[
        Change {
            path: String::from("Pizza.name"),
            kind: ChangeKind::ChangeFieldType
        },
        Change {
            path: String::from("PizzaName"),
            kind: ChangeKind::AddObjectType
        },
        Change {
            path: String::from("Topping.PINEAPPLE"),
            kind: ChangeKind::RemoveEnumValue
        },
        Change {
            path: String::from("Topping.POTATO"),
            kind: ChangeKind::AddEnumValue
        }
]);

Cargo features

  • serde: Serialize and Deserialize impls for Change (default: on).

Dependencies

~4.5MB
~70K SLoC