mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-07 08:13:18 +03:00
81ac867d16
This is Part 2 in a stacked PR set that delivers aggregate root field support. * Part 1: OpenDD: https://github.com/hasura/v3-engine/pull/683 * Part 3: GraphQL API: https://github.com/hasura/v3-engine/pull/685 JIRA: [V3ENGINE-159](https://hasurahq.atlassian.net/browse/V3ENGINE-159) ## Description This PR implements the metadata resolve phase of the engine and adds support for resolving `AggregateExpression`s and validates their use when linked to a `Model`. The bulk of the changes can be found in: * `crates/metadata-resolve/src/stages/aggregates/*` - This is where the `AggregateExpression`s are resolved * `crates/metadata-resolve/src/stages/models/mod.rs` - This is where we validate the `AggregateExpression` specified for use in the model is actually compatible with the model and its data connector The `ndc-spec` version used has been lifted to the latest version that adds support for aggregates over nested objects (https://github.com/hasura/ndc-spec/pull/144). This necessitated changes in the Custom Connector, but actual functionality to implement aggregation over nested objects is implemented in Part 3. There are also some changes in `crates/metadata-resolve/src/types/subgraph.rs` where the `Display` trait for the various `Qualified<T>`, `QualifiedTypeReference`, etc types has been reworked so that they print more cleanly, with the subgraph being put outside the type syntax, and array types getting formatted correctly. For example, previous an array of Varchars would have printed as `Varchar (in subgraph default)!`, now it properly formats as `[Varchar!]! (in subgraph default)`. This was necessary to make useful error messages using these types. A tonne of tests have been added in `crates/engine/tests/validate_metadata_artifacts/aggregate_expressions` to test every error condition of the metadata resolve process. [V3ENGINE-159]: https://hasurahq.atlassian.net/browse/V3ENGINE-159?atlOrigin=eyJpIjoiNWRkNTljNzYxNjVmNDY3MDlhMDU5Y2ZhYzA5YTRkZjUiLCJwIjoiZ2l0aHViLWNvbS1KU1cifQ V3_GIT_ORIGIN_REV_ID: ffd859127a3f1560707f06ef01906c9d1b183d31
38 lines
916 B
TOML
38 lines
916 B
TOML
[package]
|
|
name = "open-dds"
|
|
version.workspace = true
|
|
edition.workspace = true
|
|
license.workspace = true
|
|
|
|
[lib]
|
|
bench = false
|
|
|
|
[dependencies]
|
|
jsonschema-tidying = { path = "../utils/jsonschema-tidying" }
|
|
opendds-derive = { path = "../utils/opendds-derive" }
|
|
|
|
derive_more = "0.99.17"
|
|
indexmap = { version = "2", features = ["serde"] }
|
|
lazy_static = "1.4.0"
|
|
ndc-models = { git = "https://github.com/hasura/ndc-spec.git", rev = "aa8ad48e42aefd9e585a4c923bebfd56eee40204" }
|
|
ref-cast = "1.0"
|
|
schemars = { version = "0.8.20", features = ["smol_str", "preserve_order"] }
|
|
serde = "1.0.203"
|
|
serde_json = { version = "1.0.116", features = ["preserve_order"] }
|
|
serde_path_to_error = "0.1.14"
|
|
strum = "0.26.2"
|
|
strum_macros = "0.26.3"
|
|
thiserror = "1.0"
|
|
|
|
[dev-dependencies]
|
|
goldenfile = "^1.7.1"
|
|
pretty_assertions = "1.3.0"
|
|
|
|
[package.metadata.cargo-machete]
|
|
ignored = [
|
|
"strum", # used by strum_macros
|
|
]
|
|
|
|
[lints]
|
|
workspace = true
|