Skip to content

ppx/test: cover encode behavior for @drop_default variants#84

Open
Khady wants to merge 2 commits intomelange-community:mainfrom
Khady:louis/test-drop-default-gaps
Open

ppx/test: cover encode behavior for @drop_default variants#84
Khady wants to merge 2 commits intomelange-community:mainfrom
Khady:louis/test-drop-default-gaps

Conversation

@Khady
Copy link
Copy Markdown
Contributor

@Khady Khady commented Apr 28, 2026

Existing e2e runtime tests only exercised the [@option] + [@json.drop_default] combination via drop_default_option. The other three drop-default shapes had only PPX-generation coverage in ppx_deriving_json_js.t / ppx_deriving_json_native.t, but no runtime assertion that the encoder actually drops the field.

This PR adds runtime cases for the three remaining shapes so the encode behavior (drop when value matches default vs. include otherwise) is visible in the cram output:

  • [@json.default E] [@json.drop_default] (flag form, non-option default; uses equal_<type> in scope)
  • [@json.default E] [@json.drop_default expr] (custom comparator form)
  • [@json.default E] [@json.drop_default_if_json_equal]

Each new type contributes two cases: value matching the default (field dropped) and value differing (field included). Behavior is identical between native and JS backends.

This PR was motivated by a bug in ppx_deriving_jsonschema, which was struggling to handle an absent value marked with [@option] [@drop_default], as such values are serialized to undefined by melange json. It seems like a useful information to capture in the tests. Unfortunately it is not very explicit.

Khady and others added 2 commits April 28, 2026 08:34
Existing e2e tests only exercised the [@option] + [@json.drop_default]
combination. Add runtime coverage for the three remaining shapes so the
encode behavior (drop when value matches default vs include otherwise)
is visible in the cram output:

- [@json.default E] [@json.drop_default] (flag form, non-option default)
- [@json.default E] [@json.drop_default expr] (custom comparator)
- [@json.default E] [@json.drop_default_if_json_equal]

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Adds an outer record whose default for a record-typed field is a let-bound
value, where the inner record's own field uses [@option] [@json.drop_default].
Exercises three cases:

- inner foo=None present: round-trips via {"inner":{}} (foo dropped)
- inner foo=Some 5 present: round-trips via {"inner":{"foo":5}}
- outer field missing: default kicks in and decodes to the empty inner record

Previously [@json.default] was only tested with scalar literal payloads.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant