Skip to content

Commit

Permalink
fix(graphql): Adapt code to breaking change of 'gql' dependencies
Browse files Browse the repository at this point in the history
  • Loading branch information
ueman committed Aug 21, 2022
1 parent 425f648 commit 5d16ebf
Show file tree
Hide file tree
Showing 8 changed files with 65 additions and 37 deletions.
6 changes: 4 additions & 2 deletions packages/graphql/lib/src/cache/_normalizing_data_proxy.dart
Original file line number Diff line number Diff line change
Expand Up @@ -144,10 +144,11 @@ abstract class NormalizingDataProxy extends GraphQLDataProxy {
if (broadcast ?? true) {
broadcastRequested = true;
}
} on PartialDataException catch (e) {
} on PartialDataException catch (e, stackTrace) {
if (request.validatesStructureOf(data)) {
throw CacheMisconfigurationException(
e,
stackTrace,
request: request,
data: data,
);
Expand Down Expand Up @@ -182,10 +183,11 @@ abstract class NormalizingDataProxy extends GraphQLDataProxy {
if (broadcast ?? true) {
broadcastRequested = true;
}
} on PartialDataException catch (e) {
} on PartialDataException catch (e, stackTrace) {
if (request.validatesStructureOf(data)) {
throw CacheMisconfigurationException(
e,
stackTrace,
fragmentRequest: request,
data: data,
);
Expand Down
13 changes: 8 additions & 5 deletions packages/graphql/lib/src/core/_query_write_handling.dart
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ typedef _IntWriteQuery = void Function(

/// Internal [PartialDataException] handling callback
typedef _IntPartialDataHandler = MismatchedDataStructureException Function(
PartialDataException failure);
PartialDataException failure, StackTrace stackTrace);

extension InternalQueryWriteHandling on QueryManager {
/// Merges exceptions into `queryResult` and
Expand All @@ -29,10 +29,10 @@ extension InternalQueryWriteHandling on QueryManager {
exception: queryResult.exception,
linkException: failure,
);
} on PartialDataException catch (failure) {
} on PartialDataException catch (failure, stackTrace) {
queryResult!.exception = coalesceErrors(
exception: queryResult.exception,
linkException: onPartial(failure),
linkException: onPartial(failure, stackTrace),
);
}
return false;
Expand Down Expand Up @@ -61,8 +61,10 @@ extension InternalQueryWriteHandling on QueryManager {
response.data,
queryResult,
writeQuery: (req, data) => cache.writeQuery(req, data: data!),
onPartial: (failure) => UnexpectedResponseStructureException(
onPartial: (failure, stackTrace) =>
UnexpectedResponseStructureException(
failure,
stackTrace,
request: request,
parsedResponse: response,
),
Expand All @@ -84,8 +86,9 @@ extension InternalQueryWriteHandling on QueryManager {
data,
queryResult,
writeQuery: writeQuery,
onPartial: (failure) => MismatchedDataStructureException(
onPartial: (failure, stackTrace) => MismatchedDataStructureException(
failure,
stackTrace,
request: request,
data: data,
),
Expand Down
2 changes: 1 addition & 1 deletion packages/graphql/lib/src/core/query_manager.dart
Original file line number Diff line number Diff line change
Expand Up @@ -519,7 +519,7 @@ class QueryManager {

QueryResult<TParsed> _wrapFailure<TParsed>(
BaseOptions<TParsed> options,
dynamic ex,
Object ex,
StackTrace trace,
) =>
QueryResult(
Expand Down
5 changes: 3 additions & 2 deletions packages/graphql/lib/src/exceptions/exceptions.dart
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,10 @@ import 'package:graphql/src/exceptions/network.dart'
export 'package:graphql/src/exceptions/network.dart'
if (dart.library.io) 'package:graphql/src/exceptions/network_io.dart';

LinkException translateFailure(dynamic failure, StackTrace trace) {
LinkException translateFailure(Object failure, StackTrace trace) {
if (failure is LinkException) {
return failure;
}
return network.translateFailure(failure) ?? UnknownException(failure, trace);
return network.translateFailure(failure, trace) ??
UnknownException(failure, trace);
}
47 changes: 33 additions & 14 deletions packages/graphql/lib/src/exceptions/exceptions_next.dart
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ export 'package:normalize/normalize.dart' show PartialDataException;
@immutable
class CacheMissException extends LinkException {
CacheMissException(this.message, this.request, {this.expectedData})
: super(null);
: super(null, null);

final String message;
final Request request;
Expand All @@ -37,18 +37,25 @@ class CacheMissException extends LinkException {
/// [CacheMisconfigurationException].
class MismatchedDataStructureException extends LinkException {
const MismatchedDataStructureException(
this.originalException, {
this.originalException,
this.originalStackTrace, {
this.request,
required this.data,
}) : super(originalException);
}) : super(originalException, originalStackTrace);

final Map<String, dynamic>? data;
final Request? request;

@override
final PartialDataException originalException;

@override
final StackTrace originalStackTrace;

@override
String toString() => 'MismatchedDataStructureException('
'$originalException, '
'$originalStackTrace, '
'request: ${request}, '
'data: ${data}, '
')';
Expand All @@ -62,11 +69,12 @@ class MismatchedDataStructureException extends LinkException {
class CacheMisconfigurationException extends LinkException
implements MismatchedDataStructureException {
const CacheMisconfigurationException(
this.originalException, {
this.originalException,
this.originalStackTrace, {
this.request,
this.fragmentRequest,
required this.data,
}) : super(originalException);
}) : super(originalException, originalStackTrace);

final Request? request;
final FragmentRequest? fragmentRequest;
Expand All @@ -75,10 +83,14 @@ class CacheMisconfigurationException extends LinkException
@override
final PartialDataException originalException;

@override
final StackTrace originalStackTrace;

@override
String toString() => [
'CacheMisconfigurationException(',
'$originalException, ',
'$originalStackTrace, ',
if (request != null) 'request: ${request}',
if (fragmentRequest != null) 'fragmentRequest : ${fragmentRequest}',
'data: ${data}, ',
Expand All @@ -94,12 +106,15 @@ class CacheMisconfigurationException extends LinkException
class UnexpectedResponseStructureException extends ServerException
implements MismatchedDataStructureException {
const UnexpectedResponseStructureException(
this.originalException, {
this.originalException,
this.originalStackTrace, {
required this.request,
required Response parsedResponse,
}) : super(
parsedResponse: parsedResponse,
originalException: originalException);
parsedResponse: parsedResponse,
originalException: originalException,
originalStackTrace: originalStackTrace,
);

@override
final Request request;
Expand All @@ -110,9 +125,13 @@ class UnexpectedResponseStructureException extends ServerException
@override
final PartialDataException originalException;

@override
final StackTrace originalStackTrace;

@override
String toString() => 'UnexpectedResponseStructureException('
'$originalException, '
'$originalStackTrace, '
'request: ${request}, '
'parsedResponse: ${parsedResponse}, '
')';
Expand All @@ -124,13 +143,10 @@ class UnexpectedResponseStructureException extends ServerException
class UnknownException extends LinkException {
String get message => 'Unhandled Client-Side Exception: $originalException';

/// stacktrace of the [originalException].
final StackTrace originalStackTrace;

const UnknownException(
dynamic originalException,
this.originalStackTrace,
) : super(originalException);
Object originalException,
StackTrace originalStackTrace,
) : super(originalException, originalStackTrace);

@override
String toString() =>
Expand All @@ -147,8 +163,11 @@ class OperationException implements Exception {
/// Errors encountered during execution such as network or cache errors
LinkException? linkException;

StackTrace? originalStackTrace;

OperationException({
this.linkException,
this.originalStackTrace,
Iterable<GraphQLError> graphqlErrors = const [],
}) : this.graphqlErrors = graphqlErrors.toList();

Expand Down
8 changes: 5 additions & 3 deletions packages/graphql/lib/src/exceptions/network.dart
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,11 @@ import 'package:gql_link/gql_link.dart' show LinkException;
/// Exception occurring when there is a network-level error
class NetworkException extends LinkException {
NetworkException({
dynamic originalException,
required Object originalException,
StackTrace originalStackTrace = StackTrace.empty,
this.message,
required this.uri,
}) : super(originalException);
}) : super(originalException, originalStackTrace);

final String? message;
final Uri? uri;
Expand All @@ -22,10 +23,11 @@ class NetworkException extends LinkException {
/// Once `gql_link` has robust http and socket exception handling,
/// this and `./network.dart` can be removed and `./exceptions_next.dart`
/// will be all that is necessary
NetworkException? translateFailure(dynamic failure) {
NetworkException? translateFailure(Object failure, StackTrace stackTrace) {
if (failure is http.ClientException) {
return NetworkException(
originalException: failure,
originalStackTrace: stackTrace,
message: failure.message,
uri: failure.uri,
);
Expand Down
5 changes: 3 additions & 2 deletions packages/graphql/lib/src/exceptions/network_io.dart
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,11 @@ export './network.dart' show NetworkException;
/// Once `gql_link` has robust http and socket exception handling,
/// this and `./unhandled.dart` can be removed and `./exceptions_next.dart`
/// will be all that is necessary
base.NetworkException? translateFailure(dynamic failure) {
base.NetworkException? translateFailure(Object failure, StackTrace stackTrace) {
if (failure is io.SocketException) {
return base.NetworkException(
originalException: failure,
originalStackTrace: stackTrace,
message: failure.message,
uri: Uri(
scheme: 'http',
Expand All @@ -20,5 +21,5 @@ base.NetworkException? translateFailure(dynamic failure) {
),
);
}
return base.translateFailure(failure);
return base.translateFailure(failure, stackTrace);
}
16 changes: 8 additions & 8 deletions packages/graphql/pubspec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,15 @@ homepage: https://github.com/zino-app/graphql-flutter/tree/master/packages/graph
dependencies:
meta: ^1.3.0
path: ^1.8.0
gql: ^0.13.0
gql_exec: ^0.4.0
gql_link: ^0.4.2
gql_http_link: ^0.4.2
gql_transform_link: ^0.2.0
gql_error_link: ^0.2.0
gql_dedupe_link: ^2.0.0
gql: ^0.14.0
gql_exec: ^0.4.1
gql_link: ^0.5.0
gql_http_link: ^0.4.4+1
gql_transform_link: ^0.2.2
gql_error_link: ^0.2.3
gql_dedupe_link: ^2.0.3
hive: ^2.1.0
normalize: ^0.6.0
normalize: ^0.7.1
http: ^0.13.0
collection: ^1.15.0
web_socket_channel: ^2.0.0
Expand Down

0 comments on commit 5d16ebf

Please sign in to comment.