Skip to content

Commit

Permalink
Loosen must to should for serialization supporting ordered maps.
Browse files Browse the repository at this point in the history
GraphQL should work correctly with many serialization techniques, not just JSON. Even within JSON, the GraphQL spec mentions ordered maps while the JSON spec describes unordered maps. This changes the language in the GraphQL spec to:

* Use should instead of must where ordered map support might not be possible, thus supporting more environments.

* Add clarifying language to JSON encoding section describing expectations for ordering.

Fixes #168
  • Loading branch information
leebyron committed Jul 1, 2016
1 parent 6097d7b commit f7d3141
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 12 deletions.
25 changes: 16 additions & 9 deletions spec/Section 3 -- Type System.md
Original file line number Diff line number Diff line change
Expand Up @@ -241,7 +241,7 @@ While Scalar types describe the leaf values of these hierarchical queries, Objec
describe the intermediate levels.

GraphQL Objects represent a list of named fields, each of which yield a value of
a specific type. Object values are serialized as ordered maps, where the
a specific type. Object values should be serialized as ordered maps, where the
queried field names (or aliases) are the keys and the result of evaluating
the field is the value, ordered by the order in which they appear in the query.

Expand All @@ -261,8 +261,9 @@ that will yield an `Int` value, and `picture` a field that will yield a

A query of an object value must select at least one field. This selection of
fields will yield an ordered map containing exactly the subset of the object
queried, in the order in which they were queried. Only fields that are declared
on the object type may validly be queried on that object.
queried, which should be represented in the order in which they were queried.
Only fields that are declared on the object type may validly be queried on
that object.

For example, selecting all the fields of `Person`:

Expand Down Expand Up @@ -357,9 +358,15 @@ excluding fragments for which the type does not apply and fields or
fragments that are skipped via `@skip` or `@include` directives. This ordering
is correctly produced when using the {CollectFields()} algorithm.

Response formats which support ordered maps (such as JSON) must maintain this
ordering. Response formats which do not support ordered maps may disregard
this ordering.
Response formats and runtime environments capable of representing ordered maps
should maintain this ordering when possible. Serialization formats which can
only represent unordered maps should if possible retain this order
grammatically (such as JSON).

Producing a response where fields values are represented in the same order in
which they appear in the request improves human readability during debugging and
may also enable more efficient parsing of responses if the order of properties
can be anticipated.

If a fragment is spread before other fields, the fields that fragment specifies
occur in the response before the following fields.
Expand All @@ -377,7 +384,7 @@ fragment Frag on Query {
}
```

Produces the ordered result:
Should produce the ordered result:

```js
{
Expand Down Expand Up @@ -412,7 +419,7 @@ fragment Matching on Query {
}
```

Produces the ordered result:
Should produce the ordered result:

```js
{
Expand All @@ -433,7 +440,7 @@ the ordering of fields.
}
```

Produces the ordered result:
Should produce the ordered result:

```js
{
Expand Down
24 changes: 21 additions & 3 deletions spec/Section 7 -- Response.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,9 +21,8 @@ representations of the following four primitives:
* String
* Null

Serialization formats which only support an ordered map (such as JSON) must
preserve ordering as it is defined by query execution. Serialization formats
which only support an unordered map may omit this ordering information.
Serialization formats which can represent an ordered map should preserve the
order of requested fields as defined by query execution.

A serialization format may support the following primitives, however, strings
may be used as a substitute for those primitives.
Expand Down Expand Up @@ -53,6 +52,25 @@ the following JSON concepts:
| Float | Number |
| Enum Value | String |

**Object Property Ordering**

While JSON Objects are specified as an
[unordered collection of key-value pairs][rfc7159-sec4] the pairs are
represented in an ordered manner. In other words, while the JSON strings
`{ "name": "Mark", "age": 30 }` and `{ "age": 30, "name": "Mark" }` encode the
same value, they also have observably different property orderings. While not
every JSON generator allows for control over the order in which properties are
written, many do and if so should produce JSON objects with properties in the
same order as those fields were requested as defined by query execution.

Producing JSON with ordered object properties improves human readability of
responses relative to the requests during debugging and also enables more
efficient parsing of JSON responses when the order of properties can
be anticipated.

GraphQL clients may interpret JSON objects in responses as unordered.

[rfc7159-sec4]: https://tools.ietf.org/html/rfc7159#section-4


## Response Format
Expand Down

0 comments on commit f7d3141

Please sign in to comment.