Skip to content

Commit

Permalink
Declared fields must not be hidden
Browse files Browse the repository at this point in the history
  • Loading branch information
milessabin committed Jun 6, 2024
1 parent eac11d3 commit 8065ebf
Show file tree
Hide file tree
Showing 4 changed files with 64 additions and 5 deletions.
20 changes: 20 additions & 0 deletions modules/core/src/main/scala/mapping.scala
Original file line number Diff line number Diff line change
Expand Up @@ -381,6 +381,7 @@ abstract class Mapping[F[_]] {

((ancestralFieldMapping(context, fieldName), tms) match {
case (Some(fm), List(om: ObjectMapping)) if !allImplsHaveFieldMapping =>
addProblem(DeclaredFieldMappingIsHidden(om, fm)).whenA(fm.hidden) *>
addSeenFieldMapping(om, fm)

case (None, List(om: ObjectMapping)) if !(hasEnclosingSubtreeFieldMapping || allImplsHaveFieldMapping) =>
Expand Down Expand Up @@ -1371,6 +1372,25 @@ abstract class Mapping[F[_]] {
|""".stripMargin
}

/** Referenced field does not exist. */
case class DeclaredFieldMappingIsHidden(objectMapping: ObjectMapping, fieldMapping: FieldMapping)
extends ValidationFailure(Severity.Error) {
override def toString: String =
s"$productPrefix(${showNamedType(objectMapping.tpe)}.${fieldMapping.fieldName})"
override def formattedMessage: String =
s"""|Declared field mapping is hidden.
|
|- The field ${graphql(s"${showNamedType(objectMapping.tpe)}.${fieldMapping.fieldName}")} is defined by a Schema at (1).
|- The ${scala(objectMapping.showMappingType)} at (2) contains a ${scala(fieldMapping.showMappingType)} mapping for field ${graphql(fieldMapping.fieldName)} at (3).
|- This field mapping is marked as hidden.
|- ${UNDERLINED}The mappings for declared fields must not be hidden.$RESET
|
|(1) ${schema.pos}
|(2) ${objectMapping.pos}
|(3) ${fieldMapping.pos}
|""".stripMargin
}

/** GraphQL type isn't applicable for mapping type. */
case class ObjectTypeExpected(objectMapping: ObjectMapping)
extends ValidationFailure(Severity.Error) {
Expand Down
39 changes: 39 additions & 0 deletions modules/core/src/test/scala/mapping/MappingValidatorSuite.scala
Original file line number Diff line number Diff line change
Expand Up @@ -462,6 +462,45 @@ final class ValidatorSuite extends CatsEffectSuite {

}

test("declared fields must not be hidden") {

object M extends TestMapping {
val schema =
schema"""
type Query {
foo: Foo
}

type Foo {
bar: String
}
"""

override val typeMappings =
List(
ObjectMapping(
schema.ref("Query"),
List(
CursorField[String]("foo", _ => ???, Nil)
)
),
ObjectMapping(
schema.ref("Foo"),
List(
CursorField[String]("bar", _ => ???, Nil, hidden = true),
),
)
)
}

val es = M.validate()
es match {
case List(M.DeclaredFieldMappingIsHidden(_, _)) => ()
case _ => fail(es.foldMap(_.toErrorMessage))
}
}


test("unsafeValidate") {
object M extends TestMapping {
val schema =
Expand Down
2 changes: 1 addition & 1 deletion modules/generic/src/main/scala/genericmapping.scala
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ trait GenericMappingLike[F[_]] extends ScalaVersionSpecificGenericMappingLike[F]
def subtree: Boolean = true
}

def GenericField[T](fieldName: String, t: T, hidden: Boolean = true)(implicit cb: => CursorBuilder[T], pos: SourcePos): GenericField[T] =
def GenericField[T](fieldName: String, t: T, hidden: Boolean = false)(implicit cb: => CursorBuilder[T], pos: SourcePos): GenericField[T] =
new GenericField(fieldName, t, () => cb, hidden)

object semiauto {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -86,15 +86,15 @@ trait SqlSiblingListsData[F[_]] extends SqlTestMapping[F] {
tpe = AType,
fieldMappings =
List(
SqlField("id", aTable.id, key = true, hidden = true),
SqlField("id", aTable.id, key = true),
SqlObject("bs", Join(aTable.id, bTable.aId))
)
),
ObjectMapping(
tpe = BType,
fieldMappings =
List(
SqlField("id", bTable.id, key = true, hidden = true),
SqlField("id", bTable.id, key = true),
SqlObject("cs", Join(bTable.id, cTable.bId)),
SqlObject("ds", Join(bTable.id, dTable.bId))
)
Expand All @@ -103,15 +103,15 @@ trait SqlSiblingListsData[F[_]] extends SqlTestMapping[F] {
tpe = CType,
fieldMappings =
List(
SqlField("id", cTable.id, key = true, hidden = true),
SqlField("id", cTable.id, key = true),
SqlField("nameC", cTable.nameC)
)
),
ObjectMapping(
tpe = DType,
fieldMappings =
List(
SqlField("id", dTable.id, key = true, hidden = true),
SqlField("id", dTable.id, key = true),
SqlField("nameD", dTable.nameD)
)
)
Expand Down

0 comments on commit 8065ebf

Please sign in to comment.