Skip to content

Commit

Permalink
Field Merging[2/x] Compute MergedSelections w/MergingStrategy
Browse files Browse the repository at this point in the history
  • Loading branch information
AnthonyMDev committed May 1, 2024
1 parent 5748c50 commit 4fa4fea
Show file tree
Hide file tree
Showing 12 changed files with 423 additions and 55 deletions.
21 changes: 16 additions & 5 deletions Tests/ApolloCodegenInternalTestHelpers/IRBuilderTestWrapper.swift
Original file line number Diff line number Diff line change
Expand Up @@ -21,22 +21,30 @@ public class IRBuilderTestWrapper {
}

public func build(
operation operationDefinition: CompilationResult.OperationDefinition
operation operationDefinition: CompilationResult.OperationDefinition,
mergingStrategy: IR.MergedSelections.MergingStrategy = .all
) async -> IRTestWrapper<IR.Operation> {
let operation = await irBuilder.build(operation: operationDefinition)
return IRTestWrapper(
irObject: operation,
computedSelectionSetCache: .init(entityStorage: operation.entityStorage)
computedSelectionSetCache: .init(
mergingStrategy: mergingStrategy,
entityStorage: operation.entityStorage
)
)
}

public func build(
fragment fragmentDefinition: CompilationResult.FragmentDefinition
fragment fragmentDefinition: CompilationResult.FragmentDefinition,
mergingStrategy: IR.MergedSelections.MergingStrategy = .all
) async -> IRTestWrapper<IR.NamedFragment> {
let fragment = await irBuilder.build(fragment: fragmentDefinition)
return IRTestWrapper(
irObject: fragment,
computedSelectionSetCache: .init(entityStorage: fragment.entityStorage)
computedSelectionSetCache: .init(
mergingStrategy: mergingStrategy,
entityStorage: fragment.entityStorage
)
)
}

Expand All @@ -58,7 +66,10 @@ public class IRBuilderTestWrapper {

return IRTestWrapper(
irObject: fragment,
computedSelectionSetCache: .init(entityStorage: fragment.entityStorage)
computedSelectionSetCache: .init(
mergingStrategy: .all,
entityStorage: fragment.entityStorage
)
)
}
}
Expand Down
25 changes: 19 additions & 6 deletions Tests/ApolloCodegenInternalTestHelpers/IRTestWrapper.swift
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,17 @@ import GraphQLCompiler
///
/// This wrapper provides the subscripts for accessing child selections by automatically computing and storing the `ComputedSelectionSet` results as they are accessed in unit tests.
///
/// `IRTestWrapper` types should never be initialized directly. They should be created using an
/// - Warning: `IRTestWrapper` types should never be initialized directly. They should be created using an
/// `IRBuilderTestWrapper`.
@dynamicMemberLookup
public class IRTestWrapper<T: CustomDebugStringConvertible>: CustomDebugStringConvertible {
public let irObject: T
let computedSelectionSetCache: ComputedSelectionSetCache

public var mergingStrategy: MergedSelections.MergingStrategy {
computedSelectionSetCache.mergingStrategy
}

init(
irObject: T,
computedSelectionSetCache: ComputedSelectionSetCache
Expand Down Expand Up @@ -198,7 +202,10 @@ extension IRTestWrapper<IR.NamedFragmentSpread> {
public var rootField: IRTestWrapper<IR.Field> {
return IRTestWrapper<IR.Field>(
irObject: irObject.fragment.rootField,
computedSelectionSetCache: .init(entityStorage: irObject.fragment.entityStorage)
computedSelectionSetCache: .init(
mergingStrategy: self.mergingStrategy,
entityStorage: irObject.fragment.entityStorage
)
)
}

Expand Down Expand Up @@ -254,7 +261,7 @@ extension SelectionSetTestWrapper {
public subscript(fragment fragment: String) -> IRTestWrapper<IR.NamedFragmentSpread>? {
IRTestWrapper<IR.NamedFragmentSpread>(
irObject:
computed.direct?.namedFragments[fragment] ?? computed.merged.namedFragments[fragment],
computed.direct?.namedFragments[fragment] ?? computed.merged[mergingStrategy]!.namedFragments[fragment],
computedSelectionSetCache: computedSelectionSetCache
)
}
Expand All @@ -264,20 +271,26 @@ extension SelectionSetTestWrapper {

class ComputedSelectionSetCache {
private var selectionSets: [SelectionSet.TypeInfo: ComputedSelectionSet] = [:]
public let mergingStrategy: MergedSelections.MergingStrategy
public let entityStorage: DefinitionEntityStorage

init(entityStorage: DefinitionEntityStorage) {
init(
mergingStrategy: MergedSelections.MergingStrategy,
entityStorage: DefinitionEntityStorage
) {
self.mergingStrategy = mergingStrategy
self.entityStorage = entityStorage
}

func computed(for selectionSet: SelectionSet) -> ComputedSelectionSet{
func computed(for selectionSet: SelectionSet) -> ComputedSelectionSet {
if let selectionSet = selectionSets[selectionSet.typeInfo] {
return selectionSet
}

let selectionSet = ComputedSelectionSet.Builder(
directSelections: selectionSet.selections?.readOnlyView,
typeInfo: selectionSet.typeInfo,
typeInfo: selectionSet.typeInfo,
mergingStrategies: [mergingStrategy],
entityStorage: entityStorage
).build()

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,8 +50,13 @@ extension ComputedSelectionSet: ScopedChildSelectionSetAccessible {
with conditions: IR.ScopeCondition,
computedSelectionSetCache: ComputedSelectionSetCache
) -> SelectionSetTestWrapper? {
let selectionSet = direct?.inlineFragments[conditions]?.selectionSet ??
merged.inlineFragments[conditions]?.selectionSet
let selectionSet =
direct?
.inlineFragments[conditions]?
.selectionSet ??
merged[computedSelectionSetCache.mergingStrategy]!
.inlineFragments[conditions]?
.selectionSet

return SelectionSetTestWrapper(
irObject: selectionSet,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ final class AnimalKingdomIRCreationTests: XCTestCase {
try await buildOperation()

// when
let actual = rootSelectionSet.computed.merged
let actual = self.rootSelectionSet.computed.merged

// then
expect(actual).to(beEmpty())
Expand Down
Loading

0 comments on commit 4fa4fea

Please sign in to comment.