diff --git a/commitlint.yaml b/commitlint.yaml index bce3939e8a7..0efcb504435 100644 --- a/commitlint.yaml +++ b/commitlint.yaml @@ -14,6 +14,7 @@ rules: - app - dynamite - dynamite_runtime + - dynamite_end_to_end_test - file_icons - neon - neon_dashboard diff --git a/packages/dynamite/dynamite_end_to_end_test/README.md b/packages/dynamite/dynamite_end_to_end_test/README.md new file mode 100644 index 00000000000..4c1b83f523b --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/README.md @@ -0,0 +1,4 @@ +# Dynamite end to end test + +This package contains OpenAPI specs to test the [dynamite](../dynamite) generator. +This package is not meant for publishing. diff --git a/packages/dynamite/dynamite_end_to_end_test/analysis_options.yaml b/packages/dynamite/dynamite_end_to_end_test/analysis_options.yaml new file mode 100644 index 00000000000..4db3c296b81 --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/analysis_options.yaml @@ -0,0 +1 @@ +include: package:neon_lints/dart.yaml diff --git a/packages/dynamite/dynamite_end_to_end_test/generate.sh b/packages/dynamite/dynamite_end_to_end_test/generate.sh new file mode 100644 index 00000000000..e0cfb2f0b82 --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/generate.sh @@ -0,0 +1,8 @@ +#!/bin/bash +set -euxo pipefail + +( + fvm dart pub run build_runner build --delete-conflicting-outputs + fvm dart fix --apply lib/ + melos run format +) diff --git a/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.dart b/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.dart new file mode 100644 index 00000000000..dd2b6fdb67f --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.dart @@ -0,0 +1,527 @@ +// ignore_for_file: camel_case_types +// ignore_for_file: discarded_futures +// ignore_for_file: public_member_api_docs +// ignore_for_file: unreachable_switch_case + +import 'package:built_value/built_value.dart'; +import 'package:built_value/json_object.dart'; +import 'package:built_value/serializer.dart'; +import 'package:built_value/standard_json_plugin.dart'; +import 'package:dynamite_runtime/content_string.dart'; +import 'package:dynamite_runtime/http_client.dart'; + +part 'nested_ofs.openapi.g.dart'; + +class Client extends DynamiteClient { + Client( + super.baseURL, { + super.baseHeaders, + super.userAgent, + super.httpClient, + super.cookieJar, + }); + + Client.fromClient(final DynamiteClient client) + : super( + client.baseURL, + baseHeaders: client.baseHeaders, + httpClient: client.httpClient, + cookieJar: client.cookieJar, + authentications: client.authentications, + ); +} + +@BuiltValue(instantiable: false) +abstract interface class BaseInterface { + String? get attribute; +} + +abstract class Base implements BaseInterface, Built { + factory Base([final void Function(BaseBuilder)? b]) = _$Base; + + // coverage:ignore-start + const Base._(); + // coverage:ignore-end + + // coverage:ignore-start + factory Base.fromJson(final Map json) => _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + static Serializer get serializer => _$baseSerializer; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseAllOf_1Interface { + @BuiltValueField(wireName: 'attribute-allOf') + String? get attributeAllOf; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseAllOfInterface implements BaseInterface, BaseAllOf_1Interface {} + +abstract class BaseAllOf implements BaseAllOfInterface, Built { + factory BaseAllOf([final void Function(BaseAllOfBuilder)? b]) = _$BaseAllOf; + + // coverage:ignore-start + const BaseAllOf._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseAllOf.fromJson(final Map json) => _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + static Serializer get serializer => _$baseAllOfSerializer; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseOneOf1Interface { + @BuiltValueField(wireName: 'attribute-oneOf') + String? get attributeOneOf; +} + +abstract class BaseOneOf1 implements BaseOneOf1Interface, Built { + factory BaseOneOf1([final void Function(BaseOneOf1Builder)? b]) = _$BaseOneOf1; + + // coverage:ignore-start + const BaseOneOf1._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseOneOf1.fromJson(final Map json) => _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + static Serializer get serializer => _$baseOneOf1Serializer; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseOneOfInterface { + Base? get base; + BaseOneOf1? get baseOneOf1; +} + +abstract class BaseOneOf implements BaseOneOfInterface, Built { + factory BaseOneOf([final void Function(BaseOneOfBuilder)? b]) = _$BaseOneOf; + + // coverage:ignore-start + const BaseOneOf._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseOneOf.fromJson(final Map json) => _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + @BuiltValueSerializer(custom: true) + static Serializer get serializer => _$BaseOneOfSerializer(); + + JsonObject get data; +} + +class _$BaseOneOfSerializer implements PrimitiveSerializer { + @override + final Iterable types = const [BaseOneOf, _$BaseOneOf]; + + @override + final String wireName = 'BaseOneOf'; + + @override + Object serialize( + final Serializers serializers, + final BaseOneOf object, { + final FullType specifiedType = FullType.unspecified, + }) => + object.data.value; + + @override + BaseOneOf deserialize( + final Serializers serializers, + final Object data, { + final FullType specifiedType = FullType.unspecified, + }) { + final result = BaseOneOfBuilder()..data = JsonObject(data); + try { + result._base = (_jsonSerializers.deserialize(data, specifiedType: const FullType(Base))! as Base).toBuilder(); + } catch (_) {} + try { + result._baseOneOf1 = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseOneOf1))! as BaseOneOf1).toBuilder(); + } catch (_) {} + assert( + [result._base, result._baseOneOf1].where((final x) => x != null).isNotEmpty, + 'Need oneOf for ${result._data}', + ); + return result.build(); + } +} + +@BuiltValue(instantiable: false) +abstract interface class BaseAnyOf1Interface { + @BuiltValueField(wireName: 'attribute-anyOf') + String? get attributeAnyOf; +} + +abstract class BaseAnyOf1 implements BaseAnyOf1Interface, Built { + factory BaseAnyOf1([final void Function(BaseAnyOf1Builder)? b]) = _$BaseAnyOf1; + + // coverage:ignore-start + const BaseAnyOf1._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseAnyOf1.fromJson(final Map json) => _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + static Serializer get serializer => _$baseAnyOf1Serializer; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseAnyOfInterface { + Base? get base; + BaseAnyOf1? get baseAnyOf1; +} + +abstract class BaseAnyOf implements BaseAnyOfInterface, Built { + factory BaseAnyOf([final void Function(BaseAnyOfBuilder)? b]) = _$BaseAnyOf; + + // coverage:ignore-start + const BaseAnyOf._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseAnyOf.fromJson(final Map json) => _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + @BuiltValueSerializer(custom: true) + static Serializer get serializer => _$BaseAnyOfSerializer(); + + JsonObject get data; +} + +class _$BaseAnyOfSerializer implements PrimitiveSerializer { + @override + final Iterable types = const [BaseAnyOf, _$BaseAnyOf]; + + @override + final String wireName = 'BaseAnyOf'; + + @override + Object serialize( + final Serializers serializers, + final BaseAnyOf object, { + final FullType specifiedType = FullType.unspecified, + }) => + object.data.value; + + @override + BaseAnyOf deserialize( + final Serializers serializers, + final Object data, { + final FullType specifiedType = FullType.unspecified, + }) { + final result = BaseAnyOfBuilder()..data = JsonObject(data); + try { + result._base = (_jsonSerializers.deserialize(data, specifiedType: const FullType(Base))! as Base).toBuilder(); + } catch (_) {} + try { + result._baseAnyOf1 = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseAnyOf1))! as BaseAnyOf1).toBuilder(); + } catch (_) {} + assert( + [result._base, result._baseAnyOf1].where((final x) => x != null).isNotEmpty, + 'Need anyOf for ${result._data}', + ); + return result.build(); + } +} + +@BuiltValue(instantiable: false) +abstract interface class BaseNestedAllOf_3Interface { + @BuiltValueField(wireName: 'attribute-nested-allOf') + String? get attributeNestedAllOf; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseNestedAllOfInterface + implements BaseAllOfInterface, BaseOneOfInterface, BaseAnyOfInterface, BaseNestedAllOf_3Interface {} + +abstract class BaseNestedAllOf implements BaseNestedAllOfInterface, Built { + factory BaseNestedAllOf([final void Function(BaseNestedAllOfBuilder)? b]) = _$BaseNestedAllOf; + + // coverage:ignore-start + const BaseNestedAllOf._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseNestedAllOf.fromJson(final Map json) => + _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + static Serializer get serializer => _$baseNestedAllOfSerializer; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseNestedOneOf3Interface { + @BuiltValueField(wireName: 'attribute-nested-oneOf') + String? get attributeNestedOneOf; +} + +abstract class BaseNestedOneOf3 implements BaseNestedOneOf3Interface, Built { + factory BaseNestedOneOf3([final void Function(BaseNestedOneOf3Builder)? b]) = _$BaseNestedOneOf3; + + // coverage:ignore-start + const BaseNestedOneOf3._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseNestedOneOf3.fromJson(final Map json) => + _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + static Serializer get serializer => _$baseNestedOneOf3Serializer; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseNestedOneOfInterface { + BaseAllOf? get baseAllOf; + BaseOneOf? get baseOneOf; + BaseAnyOf? get baseAnyOf; + BaseNestedOneOf3? get baseNestedOneOf3; +} + +abstract class BaseNestedOneOf implements BaseNestedOneOfInterface, Built { + factory BaseNestedOneOf([final void Function(BaseNestedOneOfBuilder)? b]) = _$BaseNestedOneOf; + + // coverage:ignore-start + const BaseNestedOneOf._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseNestedOneOf.fromJson(final Map json) => + _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + @BuiltValueSerializer(custom: true) + static Serializer get serializer => _$BaseNestedOneOfSerializer(); + + JsonObject get data; +} + +class _$BaseNestedOneOfSerializer implements PrimitiveSerializer { + @override + final Iterable types = const [BaseNestedOneOf, _$BaseNestedOneOf]; + + @override + final String wireName = 'BaseNestedOneOf'; + + @override + Object serialize( + final Serializers serializers, + final BaseNestedOneOf object, { + final FullType specifiedType = FullType.unspecified, + }) => + object.data.value; + + @override + BaseNestedOneOf deserialize( + final Serializers serializers, + final Object data, { + final FullType specifiedType = FullType.unspecified, + }) { + final result = BaseNestedOneOfBuilder()..data = JsonObject(data); + try { + result._baseAllOf = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseAllOf))! as BaseAllOf).toBuilder(); + } catch (_) {} + try { + result._baseOneOf = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseOneOf))! as BaseOneOf).toBuilder(); + } catch (_) {} + try { + result._baseAnyOf = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseAnyOf))! as BaseAnyOf).toBuilder(); + } catch (_) {} + try { + result._baseNestedOneOf3 = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseNestedOneOf3))! as BaseNestedOneOf3) + .toBuilder(); + } catch (_) {} + assert( + [result._baseAllOf, result._baseOneOf, result._baseAnyOf, result._baseNestedOneOf3] + .where((final x) => x != null) + .isNotEmpty, + 'Need oneOf for ${result._data}', + ); + return result.build(); + } +} + +@BuiltValue(instantiable: false) +abstract interface class BaseNestedAnyOf3Interface { + @BuiltValueField(wireName: 'attribute-nested-anyOf') + String? get attributeNestedAnyOf; +} + +abstract class BaseNestedAnyOf3 implements BaseNestedAnyOf3Interface, Built { + factory BaseNestedAnyOf3([final void Function(BaseNestedAnyOf3Builder)? b]) = _$BaseNestedAnyOf3; + + // coverage:ignore-start + const BaseNestedAnyOf3._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseNestedAnyOf3.fromJson(final Map json) => + _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + static Serializer get serializer => _$baseNestedAnyOf3Serializer; +} + +@BuiltValue(instantiable: false) +abstract interface class BaseNestedAnyOfInterface { + BaseAllOf? get baseAllOf; + BaseOneOf? get baseOneOf; + BaseAnyOf? get baseAnyOf; + BaseNestedAnyOf3? get baseNestedAnyOf3; +} + +abstract class BaseNestedAnyOf implements BaseNestedAnyOfInterface, Built { + factory BaseNestedAnyOf([final void Function(BaseNestedAnyOfBuilder)? b]) = _$BaseNestedAnyOf; + + // coverage:ignore-start + const BaseNestedAnyOf._(); + // coverage:ignore-end + + // coverage:ignore-start + factory BaseNestedAnyOf.fromJson(final Map json) => + _jsonSerializers.deserializeWith(serializer, json)!; + // coverage:ignore-end + + // coverage:ignore-start + Map toJson() => _jsonSerializers.serializeWith(serializer, this)! as Map; + // coverage:ignore-end + + @BuiltValueSerializer(custom: true) + static Serializer get serializer => _$BaseNestedAnyOfSerializer(); + + JsonObject get data; +} + +class _$BaseNestedAnyOfSerializer implements PrimitiveSerializer { + @override + final Iterable types = const [BaseNestedAnyOf, _$BaseNestedAnyOf]; + + @override + final String wireName = 'BaseNestedAnyOf'; + + @override + Object serialize( + final Serializers serializers, + final BaseNestedAnyOf object, { + final FullType specifiedType = FullType.unspecified, + }) => + object.data.value; + + @override + BaseNestedAnyOf deserialize( + final Serializers serializers, + final Object data, { + final FullType specifiedType = FullType.unspecified, + }) { + final result = BaseNestedAnyOfBuilder()..data = JsonObject(data); + try { + result._baseAllOf = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseAllOf))! as BaseAllOf).toBuilder(); + } catch (_) {} + try { + result._baseOneOf = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseOneOf))! as BaseOneOf).toBuilder(); + } catch (_) {} + try { + result._baseAnyOf = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseAnyOf))! as BaseAnyOf).toBuilder(); + } catch (_) {} + try { + result._baseNestedAnyOf3 = + (_jsonSerializers.deserialize(data, specifiedType: const FullType(BaseNestedAnyOf3))! as BaseNestedAnyOf3) + .toBuilder(); + } catch (_) {} + assert( + [result._baseAllOf, result._baseOneOf, result._baseAnyOf, result._baseNestedAnyOf3] + .where((final x) => x != null) + .isNotEmpty, + 'Need anyOf for ${result._data}', + ); + return result.build(); + } +} + +// coverage:ignore-start +final Serializers _serializers = (Serializers().toBuilder() + ..addBuilderFactory(const FullType(Base), Base.new) + ..add(Base.serializer) + ..addBuilderFactory(const FullType(BaseAllOf), BaseAllOf.new) + ..add(BaseAllOf.serializer) + ..addBuilderFactory(const FullType(BaseOneOf), BaseOneOf.new) + ..add(BaseOneOf.serializer) + ..addBuilderFactory(const FullType(BaseOneOf1), BaseOneOf1.new) + ..add(BaseOneOf1.serializer) + ..addBuilderFactory(const FullType(BaseAnyOf), BaseAnyOf.new) + ..add(BaseAnyOf.serializer) + ..addBuilderFactory(const FullType(BaseAnyOf1), BaseAnyOf1.new) + ..add(BaseAnyOf1.serializer) + ..addBuilderFactory(const FullType(BaseNestedAllOf), BaseNestedAllOf.new) + ..add(BaseNestedAllOf.serializer) + ..addBuilderFactory(const FullType(BaseNestedOneOf), BaseNestedOneOf.new) + ..add(BaseNestedOneOf.serializer) + ..addBuilderFactory(const FullType(BaseNestedOneOf3), BaseNestedOneOf3.new) + ..add(BaseNestedOneOf3.serializer) + ..addBuilderFactory(const FullType(BaseNestedAnyOf), BaseNestedAnyOf.new) + ..add(BaseNestedAnyOf.serializer) + ..addBuilderFactory(const FullType(BaseNestedAnyOf3), BaseNestedAnyOf3.new) + ..add(BaseNestedAnyOf3.serializer)) + .build(); + +final Serializers _jsonSerializers = (_serializers.toBuilder() + ..addPlugin(StandardJsonPlugin()) + ..addPlugin(const ContentStringPlugin())) + .build(); +// coverage:ignore-end diff --git a/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.g.dart b/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.g.dart new file mode 100644 index 00000000000..164906355f1 --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.g.dart @@ -0,0 +1,1629 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'nested_ofs.openapi.dart'; + +// ************************************************************************** +// BuiltValueGenerator +// ************************************************************************** + +Serializer _$baseSerializer = _$BaseSerializer(); +Serializer _$baseAllOfSerializer = _$BaseAllOfSerializer(); +Serializer _$baseOneOf1Serializer = _$BaseOneOf1Serializer(); +Serializer _$baseAnyOf1Serializer = _$BaseAnyOf1Serializer(); +Serializer _$baseNestedAllOfSerializer = _$BaseNestedAllOfSerializer(); +Serializer _$baseNestedOneOf3Serializer = _$BaseNestedOneOf3Serializer(); +Serializer _$baseNestedAnyOf3Serializer = _$BaseNestedAnyOf3Serializer(); + +class _$BaseSerializer implements StructuredSerializer { + @override + final Iterable types = const [Base, _$Base]; + @override + final String wireName = 'Base'; + + @override + Iterable serialize(Serializers serializers, Base object, {FullType specifiedType = FullType.unspecified}) { + final result = []; + Object? value; + value = object.attribute; + if (value != null) { + result + ..add('attribute') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + return result; + } + + @override + Base deserialize(Serializers serializers, Iterable serialized, + {FullType specifiedType = FullType.unspecified}) { + final result = BaseBuilder(); + + final iterator = serialized.iterator; + while (iterator.moveNext()) { + final key = iterator.current! as String; + iterator.moveNext(); + final Object? value = iterator.current; + switch (key) { + case 'attribute': + result.attribute = serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + } + } + + return result.build(); + } +} + +class _$BaseAllOfSerializer implements StructuredSerializer { + @override + final Iterable types = const [BaseAllOf, _$BaseAllOf]; + @override + final String wireName = 'BaseAllOf'; + + @override + Iterable serialize(Serializers serializers, BaseAllOf object, + {FullType specifiedType = FullType.unspecified}) { + final result = []; + Object? value; + value = object.attribute; + if (value != null) { + result + ..add('attribute') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + value = object.attributeAllOf; + if (value != null) { + result + ..add('attribute-allOf') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + return result; + } + + @override + BaseAllOf deserialize(Serializers serializers, Iterable serialized, + {FullType specifiedType = FullType.unspecified}) { + final result = BaseAllOfBuilder(); + + final iterator = serialized.iterator; + while (iterator.moveNext()) { + final key = iterator.current! as String; + iterator.moveNext(); + final Object? value = iterator.current; + switch (key) { + case 'attribute': + result.attribute = serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + case 'attribute-allOf': + result.attributeAllOf = serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + } + } + + return result.build(); + } +} + +class _$BaseOneOf1Serializer implements StructuredSerializer { + @override + final Iterable types = const [BaseOneOf1, _$BaseOneOf1]; + @override + final String wireName = 'BaseOneOf1'; + + @override + Iterable serialize(Serializers serializers, BaseOneOf1 object, + {FullType specifiedType = FullType.unspecified}) { + final result = []; + Object? value; + value = object.attributeOneOf; + if (value != null) { + result + ..add('attribute-oneOf') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + return result; + } + + @override + BaseOneOf1 deserialize(Serializers serializers, Iterable serialized, + {FullType specifiedType = FullType.unspecified}) { + final result = BaseOneOf1Builder(); + + final iterator = serialized.iterator; + while (iterator.moveNext()) { + final key = iterator.current! as String; + iterator.moveNext(); + final Object? value = iterator.current; + switch (key) { + case 'attribute-oneOf': + result.attributeOneOf = serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + } + } + + return result.build(); + } +} + +class _$BaseAnyOf1Serializer implements StructuredSerializer { + @override + final Iterable types = const [BaseAnyOf1, _$BaseAnyOf1]; + @override + final String wireName = 'BaseAnyOf1'; + + @override + Iterable serialize(Serializers serializers, BaseAnyOf1 object, + {FullType specifiedType = FullType.unspecified}) { + final result = []; + Object? value; + value = object.attributeAnyOf; + if (value != null) { + result + ..add('attribute-anyOf') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + return result; + } + + @override + BaseAnyOf1 deserialize(Serializers serializers, Iterable serialized, + {FullType specifiedType = FullType.unspecified}) { + final result = BaseAnyOf1Builder(); + + final iterator = serialized.iterator; + while (iterator.moveNext()) { + final key = iterator.current! as String; + iterator.moveNext(); + final Object? value = iterator.current; + switch (key) { + case 'attribute-anyOf': + result.attributeAnyOf = serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + } + } + + return result.build(); + } +} + +class _$BaseNestedAllOfSerializer implements StructuredSerializer { + @override + final Iterable types = const [BaseNestedAllOf, _$BaseNestedAllOf]; + @override + final String wireName = 'BaseNestedAllOf'; + + @override + Iterable serialize(Serializers serializers, BaseNestedAllOf object, + {FullType specifiedType = FullType.unspecified}) { + final result = []; + Object? value; + value = object.attribute; + if (value != null) { + result + ..add('attribute') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + value = object.attributeAllOf; + if (value != null) { + result + ..add('attribute-allOf') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + value = object.base; + if (value != null) { + result + ..add('base') + ..add(serializers.serialize(value, specifiedType: const FullType(Base))); + } + value = object.baseOneOf1; + if (value != null) { + result + ..add('baseOneOf1') + ..add(serializers.serialize(value, specifiedType: const FullType(BaseOneOf1))); + } + value = object.baseAnyOf1; + if (value != null) { + result + ..add('baseAnyOf1') + ..add(serializers.serialize(value, specifiedType: const FullType(BaseAnyOf1))); + } + value = object.attributeNestedAllOf; + if (value != null) { + result + ..add('attribute-nested-allOf') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + return result; + } + + @override + BaseNestedAllOf deserialize(Serializers serializers, Iterable serialized, + {FullType specifiedType = FullType.unspecified}) { + final result = BaseNestedAllOfBuilder(); + + final iterator = serialized.iterator; + while (iterator.moveNext()) { + final key = iterator.current! as String; + iterator.moveNext(); + final Object? value = iterator.current; + switch (key) { + case 'attribute': + result.attribute = serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + case 'attribute-allOf': + result.attributeAllOf = serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + case 'base': + result.base.replace(serializers.deserialize(value, specifiedType: const FullType(Base))! as Base); + break; + case 'baseOneOf1': + result.baseOneOf1 + .replace(serializers.deserialize(value, specifiedType: const FullType(BaseOneOf1))! as BaseOneOf1); + break; + case 'baseAnyOf1': + result.baseAnyOf1 + .replace(serializers.deserialize(value, specifiedType: const FullType(BaseAnyOf1))! as BaseAnyOf1); + break; + case 'attribute-nested-allOf': + result.attributeNestedAllOf = + serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + } + } + + return result.build(); + } +} + +class _$BaseNestedOneOf3Serializer implements StructuredSerializer { + @override + final Iterable types = const [BaseNestedOneOf3, _$BaseNestedOneOf3]; + @override + final String wireName = 'BaseNestedOneOf3'; + + @override + Iterable serialize(Serializers serializers, BaseNestedOneOf3 object, + {FullType specifiedType = FullType.unspecified}) { + final result = []; + Object? value; + value = object.attributeNestedOneOf; + if (value != null) { + result + ..add('attribute-nested-oneOf') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + return result; + } + + @override + BaseNestedOneOf3 deserialize(Serializers serializers, Iterable serialized, + {FullType specifiedType = FullType.unspecified}) { + final result = BaseNestedOneOf3Builder(); + + final iterator = serialized.iterator; + while (iterator.moveNext()) { + final key = iterator.current! as String; + iterator.moveNext(); + final Object? value = iterator.current; + switch (key) { + case 'attribute-nested-oneOf': + result.attributeNestedOneOf = + serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + } + } + + return result.build(); + } +} + +class _$BaseNestedAnyOf3Serializer implements StructuredSerializer { + @override + final Iterable types = const [BaseNestedAnyOf3, _$BaseNestedAnyOf3]; + @override + final String wireName = 'BaseNestedAnyOf3'; + + @override + Iterable serialize(Serializers serializers, BaseNestedAnyOf3 object, + {FullType specifiedType = FullType.unspecified}) { + final result = []; + Object? value; + value = object.attributeNestedAnyOf; + if (value != null) { + result + ..add('attribute-nested-anyOf') + ..add(serializers.serialize(value, specifiedType: const FullType(String))); + } + return result; + } + + @override + BaseNestedAnyOf3 deserialize(Serializers serializers, Iterable serialized, + {FullType specifiedType = FullType.unspecified}) { + final result = BaseNestedAnyOf3Builder(); + + final iterator = serialized.iterator; + while (iterator.moveNext()) { + final key = iterator.current! as String; + iterator.moveNext(); + final Object? value = iterator.current; + switch (key) { + case 'attribute-nested-anyOf': + result.attributeNestedAnyOf = + serializers.deserialize(value, specifiedType: const FullType(String)) as String?; + break; + } + } + + return result.build(); + } +} + +abstract mixin class BaseInterfaceBuilder { + void replace(BaseInterface other); + void update(void Function(BaseInterfaceBuilder) updates); + String? get attribute; + set attribute(String? attribute); +} + +class _$Base extends Base { + @override + final String? attribute; + + factory _$Base([void Function(BaseBuilder)? updates]) => (BaseBuilder()..update(updates))._build(); + + _$Base._({this.attribute}) : super._(); + + @override + Base rebuild(void Function(BaseBuilder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseBuilder toBuilder() => BaseBuilder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is Base && attribute == other.attribute; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, attribute.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'Base')..add('attribute', attribute)).toString(); + } +} + +class BaseBuilder implements Builder, BaseInterfaceBuilder { + _$Base? _$v; + + String? _attribute; + String? get attribute => _$this._attribute; + set attribute(covariant String? attribute) => _$this._attribute = attribute; + + BaseBuilder(); + + BaseBuilder get _$this { + final $v = _$v; + if ($v != null) { + _attribute = $v.attribute; + _$v = null; + } + return this; + } + + @override + void replace(covariant Base other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$Base; + } + + @override + void update(void Function(BaseBuilder)? updates) { + if (updates != null) updates(this); + } + + @override + Base build() => _build(); + + _$Base _build() { + final _$result = _$v ?? _$Base._(attribute: attribute); + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseAllOf_1InterfaceBuilder { + void replace(BaseAllOf_1Interface other); + void update(void Function(BaseAllOf_1InterfaceBuilder) updates); + String? get attributeAllOf; + set attributeAllOf(String? attributeAllOf); +} + +abstract mixin class BaseAllOfInterfaceBuilder implements BaseInterfaceBuilder, BaseAllOf_1InterfaceBuilder { + void replace(covariant BaseAllOfInterface other); + void update(void Function(BaseAllOfInterfaceBuilder) updates); + String? get attribute; + set attribute(covariant String? attribute); + + String? get attributeAllOf; + set attributeAllOf(covariant String? attributeAllOf); +} + +class _$BaseAllOf extends BaseAllOf { + @override + final String? attribute; + @override + final String? attributeAllOf; + + factory _$BaseAllOf([void Function(BaseAllOfBuilder)? updates]) => (BaseAllOfBuilder()..update(updates))._build(); + + _$BaseAllOf._({this.attribute, this.attributeAllOf}) : super._(); + + @override + BaseAllOf rebuild(void Function(BaseAllOfBuilder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseAllOfBuilder toBuilder() => BaseAllOfBuilder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseAllOf && attribute == other.attribute && attributeAllOf == other.attributeAllOf; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, attribute.hashCode); + _$hash = $jc(_$hash, attributeAllOf.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseAllOf') + ..add('attribute', attribute) + ..add('attributeAllOf', attributeAllOf)) + .toString(); + } +} + +class BaseAllOfBuilder implements Builder, BaseAllOfInterfaceBuilder { + _$BaseAllOf? _$v; + + String? _attribute; + String? get attribute => _$this._attribute; + set attribute(covariant String? attribute) => _$this._attribute = attribute; + + String? _attributeAllOf; + String? get attributeAllOf => _$this._attributeAllOf; + set attributeAllOf(covariant String? attributeAllOf) => _$this._attributeAllOf = attributeAllOf; + + BaseAllOfBuilder(); + + BaseAllOfBuilder get _$this { + final $v = _$v; + if ($v != null) { + _attribute = $v.attribute; + _attributeAllOf = $v.attributeAllOf; + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseAllOf other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseAllOf; + } + + @override + void update(void Function(BaseAllOfBuilder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseAllOf build() => _build(); + + _$BaseAllOf _build() { + final _$result = _$v ?? _$BaseAllOf._(attribute: attribute, attributeAllOf: attributeAllOf); + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseOneOf1InterfaceBuilder { + void replace(BaseOneOf1Interface other); + void update(void Function(BaseOneOf1InterfaceBuilder) updates); + String? get attributeOneOf; + set attributeOneOf(String? attributeOneOf); +} + +class _$BaseOneOf1 extends BaseOneOf1 { + @override + final String? attributeOneOf; + + factory _$BaseOneOf1([void Function(BaseOneOf1Builder)? updates]) => (BaseOneOf1Builder()..update(updates))._build(); + + _$BaseOneOf1._({this.attributeOneOf}) : super._(); + + @override + BaseOneOf1 rebuild(void Function(BaseOneOf1Builder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseOneOf1Builder toBuilder() => BaseOneOf1Builder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseOneOf1 && attributeOneOf == other.attributeOneOf; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, attributeOneOf.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseOneOf1')..add('attributeOneOf', attributeOneOf)).toString(); + } +} + +class BaseOneOf1Builder implements Builder, BaseOneOf1InterfaceBuilder { + _$BaseOneOf1? _$v; + + String? _attributeOneOf; + String? get attributeOneOf => _$this._attributeOneOf; + set attributeOneOf(covariant String? attributeOneOf) => _$this._attributeOneOf = attributeOneOf; + + BaseOneOf1Builder(); + + BaseOneOf1Builder get _$this { + final $v = _$v; + if ($v != null) { + _attributeOneOf = $v.attributeOneOf; + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseOneOf1 other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseOneOf1; + } + + @override + void update(void Function(BaseOneOf1Builder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseOneOf1 build() => _build(); + + _$BaseOneOf1 _build() { + final _$result = _$v ?? _$BaseOneOf1._(attributeOneOf: attributeOneOf); + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseOneOfInterfaceBuilder { + void replace(BaseOneOfInterface other); + void update(void Function(BaseOneOfInterfaceBuilder) updates); + BaseBuilder get base; + set base(BaseBuilder? base); + + BaseOneOf1Builder get baseOneOf1; + set baseOneOf1(BaseOneOf1Builder? baseOneOf1); +} + +class _$BaseOneOf extends BaseOneOf { + @override + final JsonObject data; + @override + final Base? base; + @override + final BaseOneOf1? baseOneOf1; + + factory _$BaseOneOf([void Function(BaseOneOfBuilder)? updates]) => (BaseOneOfBuilder()..update(updates))._build(); + + _$BaseOneOf._({required this.data, this.base, this.baseOneOf1}) : super._() { + BuiltValueNullFieldError.checkNotNull(data, r'BaseOneOf', 'data'); + } + + @override + BaseOneOf rebuild(void Function(BaseOneOfBuilder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseOneOfBuilder toBuilder() => BaseOneOfBuilder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseOneOf && data == other.data && base == other.base && baseOneOf1 == other.baseOneOf1; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, data.hashCode); + _$hash = $jc(_$hash, base.hashCode); + _$hash = $jc(_$hash, baseOneOf1.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseOneOf') + ..add('data', data) + ..add('base', base) + ..add('baseOneOf1', baseOneOf1)) + .toString(); + } +} + +class BaseOneOfBuilder implements Builder, BaseOneOfInterfaceBuilder { + _$BaseOneOf? _$v; + + JsonObject? _data; + JsonObject? get data => _$this._data; + set data(covariant JsonObject? data) => _$this._data = data; + + BaseBuilder? _base; + BaseBuilder get base => _$this._base ??= BaseBuilder(); + set base(covariant BaseBuilder? base) => _$this._base = base; + + BaseOneOf1Builder? _baseOneOf1; + BaseOneOf1Builder get baseOneOf1 => _$this._baseOneOf1 ??= BaseOneOf1Builder(); + set baseOneOf1(covariant BaseOneOf1Builder? baseOneOf1) => _$this._baseOneOf1 = baseOneOf1; + + BaseOneOfBuilder(); + + BaseOneOfBuilder get _$this { + final $v = _$v; + if ($v != null) { + _data = $v.data; + _base = $v.base?.toBuilder(); + _baseOneOf1 = $v.baseOneOf1?.toBuilder(); + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseOneOf other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseOneOf; + } + + @override + void update(void Function(BaseOneOfBuilder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseOneOf build() => _build(); + + _$BaseOneOf _build() { + _$BaseOneOf _$result; + try { + _$result = _$v ?? + _$BaseOneOf._( + data: BuiltValueNullFieldError.checkNotNull(data, r'BaseOneOf', 'data'), + base: _base?.build(), + baseOneOf1: _baseOneOf1?.build()); + } catch (_) { + late String _$failedField; + try { + _$failedField = 'base'; + _base?.build(); + _$failedField = 'baseOneOf1'; + _baseOneOf1?.build(); + } catch (e) { + throw BuiltValueNestedFieldError(r'BaseOneOf', _$failedField, e.toString()); + } + rethrow; + } + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseAnyOf1InterfaceBuilder { + void replace(BaseAnyOf1Interface other); + void update(void Function(BaseAnyOf1InterfaceBuilder) updates); + String? get attributeAnyOf; + set attributeAnyOf(String? attributeAnyOf); +} + +class _$BaseAnyOf1 extends BaseAnyOf1 { + @override + final String? attributeAnyOf; + + factory _$BaseAnyOf1([void Function(BaseAnyOf1Builder)? updates]) => (BaseAnyOf1Builder()..update(updates))._build(); + + _$BaseAnyOf1._({this.attributeAnyOf}) : super._(); + + @override + BaseAnyOf1 rebuild(void Function(BaseAnyOf1Builder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseAnyOf1Builder toBuilder() => BaseAnyOf1Builder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseAnyOf1 && attributeAnyOf == other.attributeAnyOf; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, attributeAnyOf.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseAnyOf1')..add('attributeAnyOf', attributeAnyOf)).toString(); + } +} + +class BaseAnyOf1Builder implements Builder, BaseAnyOf1InterfaceBuilder { + _$BaseAnyOf1? _$v; + + String? _attributeAnyOf; + String? get attributeAnyOf => _$this._attributeAnyOf; + set attributeAnyOf(covariant String? attributeAnyOf) => _$this._attributeAnyOf = attributeAnyOf; + + BaseAnyOf1Builder(); + + BaseAnyOf1Builder get _$this { + final $v = _$v; + if ($v != null) { + _attributeAnyOf = $v.attributeAnyOf; + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseAnyOf1 other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseAnyOf1; + } + + @override + void update(void Function(BaseAnyOf1Builder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseAnyOf1 build() => _build(); + + _$BaseAnyOf1 _build() { + final _$result = _$v ?? _$BaseAnyOf1._(attributeAnyOf: attributeAnyOf); + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseAnyOfInterfaceBuilder { + void replace(BaseAnyOfInterface other); + void update(void Function(BaseAnyOfInterfaceBuilder) updates); + BaseBuilder get base; + set base(BaseBuilder? base); + + BaseAnyOf1Builder get baseAnyOf1; + set baseAnyOf1(BaseAnyOf1Builder? baseAnyOf1); +} + +class _$BaseAnyOf extends BaseAnyOf { + @override + final JsonObject data; + @override + final Base? base; + @override + final BaseAnyOf1? baseAnyOf1; + + factory _$BaseAnyOf([void Function(BaseAnyOfBuilder)? updates]) => (BaseAnyOfBuilder()..update(updates))._build(); + + _$BaseAnyOf._({required this.data, this.base, this.baseAnyOf1}) : super._() { + BuiltValueNullFieldError.checkNotNull(data, r'BaseAnyOf', 'data'); + } + + @override + BaseAnyOf rebuild(void Function(BaseAnyOfBuilder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseAnyOfBuilder toBuilder() => BaseAnyOfBuilder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseAnyOf && data == other.data && base == other.base && baseAnyOf1 == other.baseAnyOf1; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, data.hashCode); + _$hash = $jc(_$hash, base.hashCode); + _$hash = $jc(_$hash, baseAnyOf1.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseAnyOf') + ..add('data', data) + ..add('base', base) + ..add('baseAnyOf1', baseAnyOf1)) + .toString(); + } +} + +class BaseAnyOfBuilder implements Builder, BaseAnyOfInterfaceBuilder { + _$BaseAnyOf? _$v; + + JsonObject? _data; + JsonObject? get data => _$this._data; + set data(covariant JsonObject? data) => _$this._data = data; + + BaseBuilder? _base; + BaseBuilder get base => _$this._base ??= BaseBuilder(); + set base(covariant BaseBuilder? base) => _$this._base = base; + + BaseAnyOf1Builder? _baseAnyOf1; + BaseAnyOf1Builder get baseAnyOf1 => _$this._baseAnyOf1 ??= BaseAnyOf1Builder(); + set baseAnyOf1(covariant BaseAnyOf1Builder? baseAnyOf1) => _$this._baseAnyOf1 = baseAnyOf1; + + BaseAnyOfBuilder(); + + BaseAnyOfBuilder get _$this { + final $v = _$v; + if ($v != null) { + _data = $v.data; + _base = $v.base?.toBuilder(); + _baseAnyOf1 = $v.baseAnyOf1?.toBuilder(); + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseAnyOf other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseAnyOf; + } + + @override + void update(void Function(BaseAnyOfBuilder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseAnyOf build() => _build(); + + _$BaseAnyOf _build() { + _$BaseAnyOf _$result; + try { + _$result = _$v ?? + _$BaseAnyOf._( + data: BuiltValueNullFieldError.checkNotNull(data, r'BaseAnyOf', 'data'), + base: _base?.build(), + baseAnyOf1: _baseAnyOf1?.build()); + } catch (_) { + late String _$failedField; + try { + _$failedField = 'base'; + _base?.build(); + _$failedField = 'baseAnyOf1'; + _baseAnyOf1?.build(); + } catch (e) { + throw BuiltValueNestedFieldError(r'BaseAnyOf', _$failedField, e.toString()); + } + rethrow; + } + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseNestedAllOf_3InterfaceBuilder { + void replace(BaseNestedAllOf_3Interface other); + void update(void Function(BaseNestedAllOf_3InterfaceBuilder) updates); + String? get attributeNestedAllOf; + set attributeNestedAllOf(String? attributeNestedAllOf); +} + +abstract mixin class BaseNestedAllOfInterfaceBuilder + implements + BaseAllOfInterfaceBuilder, + BaseOneOfInterfaceBuilder, + BaseAnyOfInterfaceBuilder, + BaseNestedAllOf_3InterfaceBuilder { + void replace(covariant BaseNestedAllOfInterface other); + void update(void Function(BaseNestedAllOfInterfaceBuilder) updates); + String? get attribute; + set attribute(covariant String? attribute); + + String? get attributeAllOf; + set attributeAllOf(covariant String? attributeAllOf); + + BaseBuilder get base; + set base(covariant BaseBuilder? base); + + BaseOneOf1Builder get baseOneOf1; + set baseOneOf1(covariant BaseOneOf1Builder? baseOneOf1); + + BaseAnyOf1Builder get baseAnyOf1; + set baseAnyOf1(covariant BaseAnyOf1Builder? baseAnyOf1); + + String? get attributeNestedAllOf; + set attributeNestedAllOf(covariant String? attributeNestedAllOf); +} + +class _$BaseNestedAllOf extends BaseNestedAllOf { + @override + final String? attribute; + @override + final String? attributeAllOf; + @override + final Base? base; + @override + final BaseOneOf1? baseOneOf1; + @override + final BaseAnyOf1? baseAnyOf1; + @override + final String? attributeNestedAllOf; + + factory _$BaseNestedAllOf([void Function(BaseNestedAllOfBuilder)? updates]) => + (BaseNestedAllOfBuilder()..update(updates))._build(); + + _$BaseNestedAllOf._( + {this.attribute, this.attributeAllOf, this.base, this.baseOneOf1, this.baseAnyOf1, this.attributeNestedAllOf}) + : super._(); + + @override + BaseNestedAllOf rebuild(void Function(BaseNestedAllOfBuilder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseNestedAllOfBuilder toBuilder() => BaseNestedAllOfBuilder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseNestedAllOf && + attribute == other.attribute && + attributeAllOf == other.attributeAllOf && + base == other.base && + baseOneOf1 == other.baseOneOf1 && + baseAnyOf1 == other.baseAnyOf1 && + attributeNestedAllOf == other.attributeNestedAllOf; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, attribute.hashCode); + _$hash = $jc(_$hash, attributeAllOf.hashCode); + _$hash = $jc(_$hash, base.hashCode); + _$hash = $jc(_$hash, baseOneOf1.hashCode); + _$hash = $jc(_$hash, baseAnyOf1.hashCode); + _$hash = $jc(_$hash, attributeNestedAllOf.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseNestedAllOf') + ..add('attribute', attribute) + ..add('attributeAllOf', attributeAllOf) + ..add('base', base) + ..add('baseOneOf1', baseOneOf1) + ..add('baseAnyOf1', baseAnyOf1) + ..add('attributeNestedAllOf', attributeNestedAllOf)) + .toString(); + } +} + +class BaseNestedAllOfBuilder + implements Builder, BaseNestedAllOfInterfaceBuilder { + _$BaseNestedAllOf? _$v; + + String? _attribute; + String? get attribute => _$this._attribute; + set attribute(covariant String? attribute) => _$this._attribute = attribute; + + String? _attributeAllOf; + String? get attributeAllOf => _$this._attributeAllOf; + set attributeAllOf(covariant String? attributeAllOf) => _$this._attributeAllOf = attributeAllOf; + + BaseBuilder? _base; + BaseBuilder get base => _$this._base ??= BaseBuilder(); + set base(covariant BaseBuilder? base) => _$this._base = base; + + BaseOneOf1Builder? _baseOneOf1; + BaseOneOf1Builder get baseOneOf1 => _$this._baseOneOf1 ??= BaseOneOf1Builder(); + set baseOneOf1(covariant BaseOneOf1Builder? baseOneOf1) => _$this._baseOneOf1 = baseOneOf1; + + BaseAnyOf1Builder? _baseAnyOf1; + BaseAnyOf1Builder get baseAnyOf1 => _$this._baseAnyOf1 ??= BaseAnyOf1Builder(); + set baseAnyOf1(covariant BaseAnyOf1Builder? baseAnyOf1) => _$this._baseAnyOf1 = baseAnyOf1; + + String? _attributeNestedAllOf; + String? get attributeNestedAllOf => _$this._attributeNestedAllOf; + set attributeNestedAllOf(covariant String? attributeNestedAllOf) => + _$this._attributeNestedAllOf = attributeNestedAllOf; + + BaseNestedAllOfBuilder(); + + BaseNestedAllOfBuilder get _$this { + final $v = _$v; + if ($v != null) { + _attribute = $v.attribute; + _attributeAllOf = $v.attributeAllOf; + _base = $v.base?.toBuilder(); + _baseOneOf1 = $v.baseOneOf1?.toBuilder(); + _baseAnyOf1 = $v.baseAnyOf1?.toBuilder(); + _attributeNestedAllOf = $v.attributeNestedAllOf; + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseNestedAllOf other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseNestedAllOf; + } + + @override + void update(void Function(BaseNestedAllOfBuilder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseNestedAllOf build() => _build(); + + _$BaseNestedAllOf _build() { + _$BaseNestedAllOf _$result; + try { + _$result = _$v ?? + _$BaseNestedAllOf._( + attribute: attribute, + attributeAllOf: attributeAllOf, + base: _base?.build(), + baseOneOf1: _baseOneOf1?.build(), + baseAnyOf1: _baseAnyOf1?.build(), + attributeNestedAllOf: attributeNestedAllOf); + } catch (_) { + late String _$failedField; + try { + _$failedField = 'base'; + _base?.build(); + _$failedField = 'baseOneOf1'; + _baseOneOf1?.build(); + _$failedField = 'baseAnyOf1'; + _baseAnyOf1?.build(); + } catch (e) { + throw BuiltValueNestedFieldError(r'BaseNestedAllOf', _$failedField, e.toString()); + } + rethrow; + } + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseNestedOneOf3InterfaceBuilder { + void replace(BaseNestedOneOf3Interface other); + void update(void Function(BaseNestedOneOf3InterfaceBuilder) updates); + String? get attributeNestedOneOf; + set attributeNestedOneOf(String? attributeNestedOneOf); +} + +class _$BaseNestedOneOf3 extends BaseNestedOneOf3 { + @override + final String? attributeNestedOneOf; + + factory _$BaseNestedOneOf3([void Function(BaseNestedOneOf3Builder)? updates]) => + (BaseNestedOneOf3Builder()..update(updates))._build(); + + _$BaseNestedOneOf3._({this.attributeNestedOneOf}) : super._(); + + @override + BaseNestedOneOf3 rebuild(void Function(BaseNestedOneOf3Builder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseNestedOneOf3Builder toBuilder() => BaseNestedOneOf3Builder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseNestedOneOf3 && attributeNestedOneOf == other.attributeNestedOneOf; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, attributeNestedOneOf.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseNestedOneOf3')..add('attributeNestedOneOf', attributeNestedOneOf)) + .toString(); + } +} + +class BaseNestedOneOf3Builder + implements Builder, BaseNestedOneOf3InterfaceBuilder { + _$BaseNestedOneOf3? _$v; + + String? _attributeNestedOneOf; + String? get attributeNestedOneOf => _$this._attributeNestedOneOf; + set attributeNestedOneOf(covariant String? attributeNestedOneOf) => + _$this._attributeNestedOneOf = attributeNestedOneOf; + + BaseNestedOneOf3Builder(); + + BaseNestedOneOf3Builder get _$this { + final $v = _$v; + if ($v != null) { + _attributeNestedOneOf = $v.attributeNestedOneOf; + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseNestedOneOf3 other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseNestedOneOf3; + } + + @override + void update(void Function(BaseNestedOneOf3Builder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseNestedOneOf3 build() => _build(); + + _$BaseNestedOneOf3 _build() { + final _$result = _$v ?? _$BaseNestedOneOf3._(attributeNestedOneOf: attributeNestedOneOf); + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseNestedOneOfInterfaceBuilder { + void replace(BaseNestedOneOfInterface other); + void update(void Function(BaseNestedOneOfInterfaceBuilder) updates); + BaseAllOfBuilder get baseAllOf; + set baseAllOf(BaseAllOfBuilder? baseAllOf); + + BaseOneOfBuilder get baseOneOf; + set baseOneOf(BaseOneOfBuilder? baseOneOf); + + BaseAnyOfBuilder get baseAnyOf; + set baseAnyOf(BaseAnyOfBuilder? baseAnyOf); + + BaseNestedOneOf3Builder get baseNestedOneOf3; + set baseNestedOneOf3(BaseNestedOneOf3Builder? baseNestedOneOf3); +} + +class _$BaseNestedOneOf extends BaseNestedOneOf { + @override + final JsonObject data; + @override + final BaseAllOf? baseAllOf; + @override + final BaseOneOf? baseOneOf; + @override + final BaseAnyOf? baseAnyOf; + @override + final BaseNestedOneOf3? baseNestedOneOf3; + + factory _$BaseNestedOneOf([void Function(BaseNestedOneOfBuilder)? updates]) => + (BaseNestedOneOfBuilder()..update(updates))._build(); + + _$BaseNestedOneOf._({required this.data, this.baseAllOf, this.baseOneOf, this.baseAnyOf, this.baseNestedOneOf3}) + : super._() { + BuiltValueNullFieldError.checkNotNull(data, r'BaseNestedOneOf', 'data'); + } + + @override + BaseNestedOneOf rebuild(void Function(BaseNestedOneOfBuilder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseNestedOneOfBuilder toBuilder() => BaseNestedOneOfBuilder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseNestedOneOf && + data == other.data && + baseAllOf == other.baseAllOf && + baseOneOf == other.baseOneOf && + baseAnyOf == other.baseAnyOf && + baseNestedOneOf3 == other.baseNestedOneOf3; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, data.hashCode); + _$hash = $jc(_$hash, baseAllOf.hashCode); + _$hash = $jc(_$hash, baseOneOf.hashCode); + _$hash = $jc(_$hash, baseAnyOf.hashCode); + _$hash = $jc(_$hash, baseNestedOneOf3.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseNestedOneOf') + ..add('data', data) + ..add('baseAllOf', baseAllOf) + ..add('baseOneOf', baseOneOf) + ..add('baseAnyOf', baseAnyOf) + ..add('baseNestedOneOf3', baseNestedOneOf3)) + .toString(); + } +} + +class BaseNestedOneOfBuilder + implements Builder, BaseNestedOneOfInterfaceBuilder { + _$BaseNestedOneOf? _$v; + + JsonObject? _data; + JsonObject? get data => _$this._data; + set data(covariant JsonObject? data) => _$this._data = data; + + BaseAllOfBuilder? _baseAllOf; + BaseAllOfBuilder get baseAllOf => _$this._baseAllOf ??= BaseAllOfBuilder(); + set baseAllOf(covariant BaseAllOfBuilder? baseAllOf) => _$this._baseAllOf = baseAllOf; + + BaseOneOfBuilder? _baseOneOf; + BaseOneOfBuilder get baseOneOf => _$this._baseOneOf ??= BaseOneOfBuilder(); + set baseOneOf(covariant BaseOneOfBuilder? baseOneOf) => _$this._baseOneOf = baseOneOf; + + BaseAnyOfBuilder? _baseAnyOf; + BaseAnyOfBuilder get baseAnyOf => _$this._baseAnyOf ??= BaseAnyOfBuilder(); + set baseAnyOf(covariant BaseAnyOfBuilder? baseAnyOf) => _$this._baseAnyOf = baseAnyOf; + + BaseNestedOneOf3Builder? _baseNestedOneOf3; + BaseNestedOneOf3Builder get baseNestedOneOf3 => _$this._baseNestedOneOf3 ??= BaseNestedOneOf3Builder(); + set baseNestedOneOf3(covariant BaseNestedOneOf3Builder? baseNestedOneOf3) => + _$this._baseNestedOneOf3 = baseNestedOneOf3; + + BaseNestedOneOfBuilder(); + + BaseNestedOneOfBuilder get _$this { + final $v = _$v; + if ($v != null) { + _data = $v.data; + _baseAllOf = $v.baseAllOf?.toBuilder(); + _baseOneOf = $v.baseOneOf?.toBuilder(); + _baseAnyOf = $v.baseAnyOf?.toBuilder(); + _baseNestedOneOf3 = $v.baseNestedOneOf3?.toBuilder(); + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseNestedOneOf other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseNestedOneOf; + } + + @override + void update(void Function(BaseNestedOneOfBuilder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseNestedOneOf build() => _build(); + + _$BaseNestedOneOf _build() { + _$BaseNestedOneOf _$result; + try { + _$result = _$v ?? + _$BaseNestedOneOf._( + data: BuiltValueNullFieldError.checkNotNull(data, r'BaseNestedOneOf', 'data'), + baseAllOf: _baseAllOf?.build(), + baseOneOf: _baseOneOf?.build(), + baseAnyOf: _baseAnyOf?.build(), + baseNestedOneOf3: _baseNestedOneOf3?.build()); + } catch (_) { + late String _$failedField; + try { + _$failedField = 'baseAllOf'; + _baseAllOf?.build(); + _$failedField = 'baseOneOf'; + _baseOneOf?.build(); + _$failedField = 'baseAnyOf'; + _baseAnyOf?.build(); + _$failedField = 'baseNestedOneOf3'; + _baseNestedOneOf3?.build(); + } catch (e) { + throw BuiltValueNestedFieldError(r'BaseNestedOneOf', _$failedField, e.toString()); + } + rethrow; + } + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseNestedAnyOf3InterfaceBuilder { + void replace(BaseNestedAnyOf3Interface other); + void update(void Function(BaseNestedAnyOf3InterfaceBuilder) updates); + String? get attributeNestedAnyOf; + set attributeNestedAnyOf(String? attributeNestedAnyOf); +} + +class _$BaseNestedAnyOf3 extends BaseNestedAnyOf3 { + @override + final String? attributeNestedAnyOf; + + factory _$BaseNestedAnyOf3([void Function(BaseNestedAnyOf3Builder)? updates]) => + (BaseNestedAnyOf3Builder()..update(updates))._build(); + + _$BaseNestedAnyOf3._({this.attributeNestedAnyOf}) : super._(); + + @override + BaseNestedAnyOf3 rebuild(void Function(BaseNestedAnyOf3Builder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseNestedAnyOf3Builder toBuilder() => BaseNestedAnyOf3Builder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseNestedAnyOf3 && attributeNestedAnyOf == other.attributeNestedAnyOf; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, attributeNestedAnyOf.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseNestedAnyOf3')..add('attributeNestedAnyOf', attributeNestedAnyOf)) + .toString(); + } +} + +class BaseNestedAnyOf3Builder + implements Builder, BaseNestedAnyOf3InterfaceBuilder { + _$BaseNestedAnyOf3? _$v; + + String? _attributeNestedAnyOf; + String? get attributeNestedAnyOf => _$this._attributeNestedAnyOf; + set attributeNestedAnyOf(covariant String? attributeNestedAnyOf) => + _$this._attributeNestedAnyOf = attributeNestedAnyOf; + + BaseNestedAnyOf3Builder(); + + BaseNestedAnyOf3Builder get _$this { + final $v = _$v; + if ($v != null) { + _attributeNestedAnyOf = $v.attributeNestedAnyOf; + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseNestedAnyOf3 other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseNestedAnyOf3; + } + + @override + void update(void Function(BaseNestedAnyOf3Builder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseNestedAnyOf3 build() => _build(); + + _$BaseNestedAnyOf3 _build() { + final _$result = _$v ?? _$BaseNestedAnyOf3._(attributeNestedAnyOf: attributeNestedAnyOf); + replace(_$result); + return _$result; + } +} + +abstract mixin class BaseNestedAnyOfInterfaceBuilder { + void replace(BaseNestedAnyOfInterface other); + void update(void Function(BaseNestedAnyOfInterfaceBuilder) updates); + BaseAllOfBuilder get baseAllOf; + set baseAllOf(BaseAllOfBuilder? baseAllOf); + + BaseOneOfBuilder get baseOneOf; + set baseOneOf(BaseOneOfBuilder? baseOneOf); + + BaseAnyOfBuilder get baseAnyOf; + set baseAnyOf(BaseAnyOfBuilder? baseAnyOf); + + BaseNestedAnyOf3Builder get baseNestedAnyOf3; + set baseNestedAnyOf3(BaseNestedAnyOf3Builder? baseNestedAnyOf3); +} + +class _$BaseNestedAnyOf extends BaseNestedAnyOf { + @override + final JsonObject data; + @override + final BaseAllOf? baseAllOf; + @override + final BaseOneOf? baseOneOf; + @override + final BaseAnyOf? baseAnyOf; + @override + final BaseNestedAnyOf3? baseNestedAnyOf3; + + factory _$BaseNestedAnyOf([void Function(BaseNestedAnyOfBuilder)? updates]) => + (BaseNestedAnyOfBuilder()..update(updates))._build(); + + _$BaseNestedAnyOf._({required this.data, this.baseAllOf, this.baseOneOf, this.baseAnyOf, this.baseNestedAnyOf3}) + : super._() { + BuiltValueNullFieldError.checkNotNull(data, r'BaseNestedAnyOf', 'data'); + } + + @override + BaseNestedAnyOf rebuild(void Function(BaseNestedAnyOfBuilder) updates) => (toBuilder()..update(updates)).build(); + + @override + BaseNestedAnyOfBuilder toBuilder() => BaseNestedAnyOfBuilder()..replace(this); + + @override + bool operator ==(Object other) { + if (identical(other, this)) return true; + return other is BaseNestedAnyOf && + data == other.data && + baseAllOf == other.baseAllOf && + baseOneOf == other.baseOneOf && + baseAnyOf == other.baseAnyOf && + baseNestedAnyOf3 == other.baseNestedAnyOf3; + } + + @override + int get hashCode { + var _$hash = 0; + _$hash = $jc(_$hash, data.hashCode); + _$hash = $jc(_$hash, baseAllOf.hashCode); + _$hash = $jc(_$hash, baseOneOf.hashCode); + _$hash = $jc(_$hash, baseAnyOf.hashCode); + _$hash = $jc(_$hash, baseNestedAnyOf3.hashCode); + _$hash = $jf(_$hash); + return _$hash; + } + + @override + String toString() { + return (newBuiltValueToStringHelper(r'BaseNestedAnyOf') + ..add('data', data) + ..add('baseAllOf', baseAllOf) + ..add('baseOneOf', baseOneOf) + ..add('baseAnyOf', baseAnyOf) + ..add('baseNestedAnyOf3', baseNestedAnyOf3)) + .toString(); + } +} + +class BaseNestedAnyOfBuilder + implements Builder, BaseNestedAnyOfInterfaceBuilder { + _$BaseNestedAnyOf? _$v; + + JsonObject? _data; + JsonObject? get data => _$this._data; + set data(covariant JsonObject? data) => _$this._data = data; + + BaseAllOfBuilder? _baseAllOf; + BaseAllOfBuilder get baseAllOf => _$this._baseAllOf ??= BaseAllOfBuilder(); + set baseAllOf(covariant BaseAllOfBuilder? baseAllOf) => _$this._baseAllOf = baseAllOf; + + BaseOneOfBuilder? _baseOneOf; + BaseOneOfBuilder get baseOneOf => _$this._baseOneOf ??= BaseOneOfBuilder(); + set baseOneOf(covariant BaseOneOfBuilder? baseOneOf) => _$this._baseOneOf = baseOneOf; + + BaseAnyOfBuilder? _baseAnyOf; + BaseAnyOfBuilder get baseAnyOf => _$this._baseAnyOf ??= BaseAnyOfBuilder(); + set baseAnyOf(covariant BaseAnyOfBuilder? baseAnyOf) => _$this._baseAnyOf = baseAnyOf; + + BaseNestedAnyOf3Builder? _baseNestedAnyOf3; + BaseNestedAnyOf3Builder get baseNestedAnyOf3 => _$this._baseNestedAnyOf3 ??= BaseNestedAnyOf3Builder(); + set baseNestedAnyOf3(covariant BaseNestedAnyOf3Builder? baseNestedAnyOf3) => + _$this._baseNestedAnyOf3 = baseNestedAnyOf3; + + BaseNestedAnyOfBuilder(); + + BaseNestedAnyOfBuilder get _$this { + final $v = _$v; + if ($v != null) { + _data = $v.data; + _baseAllOf = $v.baseAllOf?.toBuilder(); + _baseOneOf = $v.baseOneOf?.toBuilder(); + _baseAnyOf = $v.baseAnyOf?.toBuilder(); + _baseNestedAnyOf3 = $v.baseNestedAnyOf3?.toBuilder(); + _$v = null; + } + return this; + } + + @override + void replace(covariant BaseNestedAnyOf other) { + ArgumentError.checkNotNull(other, 'other'); + _$v = other as _$BaseNestedAnyOf; + } + + @override + void update(void Function(BaseNestedAnyOfBuilder)? updates) { + if (updates != null) updates(this); + } + + @override + BaseNestedAnyOf build() => _build(); + + _$BaseNestedAnyOf _build() { + _$BaseNestedAnyOf _$result; + try { + _$result = _$v ?? + _$BaseNestedAnyOf._( + data: BuiltValueNullFieldError.checkNotNull(data, r'BaseNestedAnyOf', 'data'), + baseAllOf: _baseAllOf?.build(), + baseOneOf: _baseOneOf?.build(), + baseAnyOf: _baseAnyOf?.build(), + baseNestedAnyOf3: _baseNestedAnyOf3?.build()); + } catch (_) { + late String _$failedField; + try { + _$failedField = 'baseAllOf'; + _baseAllOf?.build(); + _$failedField = 'baseOneOf'; + _baseOneOf?.build(); + _$failedField = 'baseAnyOf'; + _baseAnyOf?.build(); + _$failedField = 'baseNestedAnyOf3'; + _baseNestedAnyOf3?.build(); + } catch (e) { + throw BuiltValueNestedFieldError(r'BaseNestedAnyOf', _$failedField, e.toString()); + } + rethrow; + } + replace(_$result); + return _$result; + } +} + +// ignore_for_file: deprecated_member_use_from_same_package,type=lint diff --git a/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.json b/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.json new file mode 100644 index 00000000000..0986b256c00 --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/lib/nested_ofs.openapi.json @@ -0,0 +1,129 @@ +{ + "openapi": "3.1.0", + "info": { + "title": "nested ofs test", + "version": "0.0.1" + }, + "components": { + "schemas": { + "Base": { + "type": "object", + "properties": { + "attribute": { + "type": "string" + } + } + }, + "BaseAllOf": { + "allOf": [ + { + "$ref": "#/components/schemas/Base" + }, + { + "type": "object", + "properties": { + "attribute-allOf": { + "type": "string" + } + } + } + ] + }, + "BaseOneOf": { + "oneOf": [ + { + "$ref": "#/components/schemas/Base" + }, + { + "type": "object", + "properties": { + "attribute-oneOf": { + "type": "string" + } + } + } + ] + }, + "BaseAnyOf": { + "anyOf": [ + { + "$ref": "#/components/schemas/Base" + }, + { + "type": "object", + "properties": { + "attribute-anyOf": { + "type": "string" + } + } + } + ] + }, + "BaseNestedAllOf": { + "allOf": [ + { + "$ref": "#/components/schemas/BaseAllOf" + }, + { + "$ref": "#/components/schemas/BaseOneOf" + }, + { + "$ref": "#/components/schemas/BaseAnyOf" + }, + { + "type": "object", + "properties": { + "attribute-nested-allOf": { + "type": "string" + } + } + } + ] + }, + "BaseNestedOneOf": { + "oneOf": [ + { + "$ref": "#/components/schemas/BaseAllOf" + }, + { + "$ref": "#/components/schemas/BaseOneOf" + }, + { + "$ref": "#/components/schemas/BaseAnyOf" + }, + { + "type": "object", + "properties": { + "attribute-nested-oneOf": { + "type": "string" + } + } + } + ] + }, + "BaseNestedAnyOf": { + "anyOf": [ + { + "$ref": "#/components/schemas/BaseAllOf" + }, + { + "$ref": "#/components/schemas/BaseOneOf" + }, + { + "$ref": "#/components/schemas/BaseAnyOf" + }, + { + "type": "object", + "properties": { + "attribute-nested-anyOf": { + "type": "string" + } + } + } + ] + } + } + }, + "paths": {}, + "tags": [] +} diff --git a/packages/dynamite/dynamite_end_to_end_test/pubspec.yaml b/packages/dynamite/dynamite_end_to_end_test/pubspec.yaml new file mode 100644 index 00000000000..e577f86803d --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/pubspec.yaml @@ -0,0 +1,27 @@ +name: dynamite_end_to_end_test +publish_to: none +description: Tests for dynamite. Not meant for publishing. +version: 1.0.0 + +environment: + sdk: '>=3.1.1 <4.0.0' + +dependencies: + built_value: ^8.6.2 + dynamite_runtime: + git: + url: https://github.com/nextcloud/neon + path: packages/dynamite/dynamite_runtime +dev_dependencies: + build_runner: ^2.4.6 + build_verify: ^3.1.0 + built_value_generator: ^8.6.2 + dynamite: + git: + url: https://github.com/nextcloud/neon + path: packages/dynamite/dynamite + neon_lints: + git: + url: https://github.com/nextcloud/neon + path: packages/neon_lints + test: ^1.24.8 diff --git a/packages/dynamite/dynamite_end_to_end_test/pubspec_overrides.yaml b/packages/dynamite/dynamite_end_to_end_test/pubspec_overrides.yaml new file mode 100644 index 00000000000..6271ab73042 --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/pubspec_overrides.yaml @@ -0,0 +1,8 @@ +# melos_managed_dependency_overrides: dynamite,dynamite_runtime,neon_lints +dependency_overrides: + dynamite: + path: ../dynamite + dynamite_runtime: + path: ../dynamite_runtime + neon_lints: + path: ../../neon_lints diff --git a/packages/dynamite/dynamite_end_to_end_test/test/ensure_validity_test.dart b/packages/dynamite/dynamite_end_to_end_test/test/ensure_validity_test.dart new file mode 100644 index 00000000000..37a272dd898 --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/test/ensure_validity_test.dart @@ -0,0 +1,13 @@ +import 'package:build_verify/build_verify.dart'; +import 'package:test/test.dart'; + +void main() { + test( + 'ensure_build', + () async => expectBuildClean( + packageRelativeDirectory: 'packages/dynamite/dynamite_end_to_end_test', + customCommand: ['bash', 'generate.sh'], + ), + timeout: const Timeout.factor(2), + ); +} diff --git a/packages/dynamite/dynamite_end_to_end_test/test/nested_ofs_test.dart b/packages/dynamite/dynamite_end_to_end_test/test/nested_ofs_test.dart new file mode 100644 index 00000000000..16ca96a3286 --- /dev/null +++ b/packages/dynamite/dynamite_end_to_end_test/test/nested_ofs_test.dart @@ -0,0 +1,91 @@ +import 'package:built_value/json_object.dart'; +import 'package:dynamite_end_to_end_test/nested_ofs.openapi.dart'; +import 'package:test/test.dart'; + +void main() { + test('BaseNestedAllOf', () { + final object = BaseNestedAllOf( + (final b) => b + ..attribute = 'attributeValue' + ..attributeAllOf = 'attributeAllOfValue' + ..attributeNestedAllOf = 'attributeNestedAllOf' + ..base.update( + (final b) => b..attribute = 'baseAttributeValue', + ) + ..baseAnyOf1.update( + (final b) => b..attributeAnyOf = 'baseAnyOfAttributeAnyOfValue', + ) + ..baseOneOf1.update( + (final b) => b..attributeOneOf = 'baseAnyOfAttributeOneOfValue', + ), + ); + + final json = { + 'attribute': 'attributeValue', + 'attribute-allOf': 'attributeAllOfValue', + 'base': {'attribute': 'baseAttributeValue'}, + 'baseOneOf1': {'attribute-oneOf': 'baseAnyOfAttributeOneOfValue'}, + 'baseAnyOf1': {'attribute-anyOf': 'baseAnyOfAttributeAnyOfValue'}, + 'attribute-nested-allOf': 'attributeNestedAllOf', + }; + + expect(object.toJson(), equals(json)); + expect(BaseNestedAllOf.fromJson(json), equals(object)); + }); + + test('BaseNestedOneOf', () { + final object = BaseNestedOneOf( + (final b) => b + ..data = JsonObject(['attribute-oneOf', 'baseOneOfAttributeOneOfValue']) + ..baseAllOf.update((final b) {}) + ..baseOneOf.update( + (final b) => b + ..data = JsonObject(['attribute-oneOf', 'baseOneOfAttributeOneOfValue']) + ..base.update((final b) {}) + ..baseOneOf1.attributeOneOf = 'baseOneOfAttributeOneOfValue', + ) + ..baseAnyOf.update( + (final b) => b + ..data = JsonObject(['attribute-oneOf', 'baseOneOfAttributeOneOfValue']) + ..base.update((final b) {}) + ..baseAnyOf1.update((final b) {}), + ) + ..baseNestedOneOf3.update((final b) {}), + ); + + final json = { + 'attribute-oneOf': 'baseOneOfAttributeOneOfValue', + }; + + expect(object.toJson(), equals(json)); + expect(BaseNestedOneOf.fromJson(json), equals(object)); + }); + + test('BaseNestedAnyOf', () { + final object = BaseNestedAnyOf( + (final b) => b + ..data = JsonObject(['attribute-oneOf', 'baseOneOfAttributeOneOfValue']) + ..baseAllOf.update((final b) {}) + ..baseOneOf.update( + (final b) => b + ..data = JsonObject(['attribute-oneOf', 'baseOneOfAttributeOneOfValue']) + ..base.update((final b) {}) + ..baseOneOf1.attributeOneOf = 'baseOneOfAttributeOneOfValue', + ) + ..baseAnyOf.update( + (final b) => b + ..data = JsonObject(['attribute-oneOf', 'baseOneOfAttributeOneOfValue']) + ..base.update((final b) {}) + ..baseAnyOf1.update((final b) {}), + ) + ..baseNestedAnyOf3.update((final b) {}), + ); + + final json = { + 'attribute-oneOf': 'baseOneOfAttributeOneOfValue', + }; + + expect(object.toJson(), equals(json)); + expect(BaseNestedAnyOf.fromJson(json), equals(object)); + }); +} diff --git a/tool/generate-dynamite-e2e-test.sh b/tool/generate-dynamite-e2e-test.sh new file mode 100755 index 00000000000..7e8b77f75f9 --- /dev/null +++ b/tool/generate-dynamite-e2e-test.sh @@ -0,0 +1,9 @@ +#!/bin/bash +set -euxo pipefail +cd "$(dirname "$0")/.." + +( + cd packages/dynamite/dynamite_end_to_end_test + rm -rf .dart_tool/build/generated/dynamite + bash generate.sh +)