Skip to content

Commit

Permalink
Add test to spot FAPI/CAPI incompatability
Browse files Browse the repository at this point in the history
We're adding a test that will break at build time rather than runtime if
our versions of the FAPI & CAPI clients are incompatible.

See also:

* #25139 (comment)
* https://github.com/guardian/ophan/pull/4719/files#diff-ee7f97c92065084bba37d70d043ad0daa0d7745f235d0ad3206b59f073829529
  • Loading branch information
rtyley committed Jun 29, 2022
1 parent 7830dfc commit 1ec73d4
Showing 1 changed file with 35 additions and 0 deletions.
35 changes: 35 additions & 0 deletions facia-press/test/frontpress/FaciaClientTest.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
package frontpress

import com.gu.contentapi.client.model.SearchQuery
import org.scalatest.concurrent.{IntegrationPatience, ScalaFutures}
import org.scalatest.{BeforeAndAfterAll, EitherValues}
import org.scalatest.flatspec._
import org.scalatest.matchers.should.Matchers
import test.{SingleServerSuite, WithMaterializer, WithTestContentApiClient, WithTestWsClient}

class FaciaClientTest extends AnyFlatSpec with Matchers
with ScalaFutures
with IntegrationPatience
with SingleServerSuite
with BeforeAndAfterAll
with WithMaterializer
with WithTestWsClient
with WithTestContentApiClient
with EitherValues {

"FAPI Client" should "perform a CAPI-client request without a runtime error like java.lang.NoSuchMethodError" in {
// See https://github.com/guardian/frontend/pull/25139#issuecomment-1163407402
// The FAPI client uses the Content API client. If this test fails with a java.lang.NoSuchMethodError, the
// versions of FAPI client and CAPI client we are using are incompatible - the FAPI client will have been
// compiled against a different version of the CAPI client.

whenReady(com.gu.facia.api.contentapi.ContentApi.getHydrateResponse(testContentApiClient.thriftClient, Seq(
SearchQuery().tag("profile/roberto-tyley"),
SearchQuery().tag("stage/comedy")
)).asFuture) { responses =>
val boo: Int = responses.value.size
boo shouldBe(2)
}
}

}

0 comments on commit 1ec73d4

Please sign in to comment.