Skip to content

Commit

Permalink
[bugfix] Make sure error is not swallowed
Browse files Browse the repository at this point in the history
  • Loading branch information
adamretter committed Nov 6, 2023
1 parent b234776 commit aa101ad
Showing 1 changed file with 26 additions and 14 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/basic/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/basic/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/basic/VSK.TEST.xml"))
Expand Down Expand Up @@ -89,7 +90,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/element-without-attributes/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/element-without-attributes/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/element-without-attributes/algolia-test.xml"))
Expand Down Expand Up @@ -123,7 +125,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/predicate/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/predicate/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/predicate/VSK.TEST.xml"))
Expand Down Expand Up @@ -167,7 +170,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/multi-predicates/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/multi-predicates/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/multi-predicates/algolia-test.xml"))
Expand Down Expand Up @@ -197,7 +201,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/user-specified-docId/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/user-specified-docId/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/user-specified-docId/VSK.TEST.xml"))
Expand Down Expand Up @@ -244,7 +249,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/user-specified-docId-and-nodeId/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/user-specified-docId-and-nodeId/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/user-specified-docId-and-nodeId/VSK.TEST.xml"))
Expand Down Expand Up @@ -290,7 +296,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-text-nodes/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-text-nodes/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-text-nodes/MZ.RGJS.xml"))
Expand Down Expand Up @@ -318,7 +325,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-attributes/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-attributes/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-attributes/MZ.RGJS.xml"))
Expand Down Expand Up @@ -346,7 +354,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-text-nodes-and-attributes/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-text-nodes-and-attributes/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-text-nodes-and-attributes/MZ.RGJS.xml"))
Expand Down Expand Up @@ -374,7 +383,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-mixed-content-nodes/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-mixed-content-nodes/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/object-based-mixed-content-nodes/mixed-content-etyms.xml"))
Expand Down Expand Up @@ -402,7 +412,8 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
val algoliaIndex = createAndRegisterAlgoliaIndex(system, Some(testActor))

// set up an index configuration
storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/attribute-based-text-nodes/collection.xconf"))
val collectionConfigPath = storeCollectionConfig(algoliaIndex, testCollectionPath, getTestResource("integration/attribute-based-text-nodes/collection.xconf"))
collectionConfigPath must beRight

// store some data (which will be indexed)
val (collectionId, docId) = storeTestDocument(algoliaIndex, testCollectionPath, getTestResource("integration/attribute-based-text-nodes/VSK.SR.xml"))
Expand Down Expand Up @@ -450,20 +461,21 @@ class AlgoliaStreamListenerIntegrationSpec extends Specification with ExistServe
algoliaIndex
}

private def storeCollectionConfig(algoliaIndex: AlgoliaIndex, testCollectionPath: XmldbURI, collectionXconfFile: Path)(implicit brokerPool: BrokerPool) {
private def storeCollectionConfig(algoliaIndex: AlgoliaIndex, testCollectionPath: XmldbURI, collectionXconfFile: Path)(implicit brokerPool: BrokerPool) : Either[Exception, XmldbURI] = {
Using(new FileInputSource(collectionXconfFile)) { collectionConf =>
withBroker { broker =>
withTxn { txn =>
injectAlgoliaIndexWorkerIfNotPresent(broker, algoliaIndex)

Using(broker.getOrCreateCollection(txn, XmldbURI.CONFIG_COLLECTION_URI.append(testCollectionPath))) { collection =>
broker.saveCollection(txn, collection)

broker.storeDocument(txn, CollectionConfiguration.DEFAULT_COLLECTION_CONFIG_FILE_URI, collectionConf, MimeType.XML_TYPE, collection)

XmldbURI.CONFIG_COLLECTION_URI.append(testCollectionPath).append(CollectionConfiguration.DEFAULT_COLLECTION_CONFIG_FILE_URI)
}.get
}
}
}.get
}.get.flatten
}

private def storeTestDocument(algoliaIndex: AlgoliaIndex, testCollectionPath: XmldbURI, documentFile: Path)(implicit brokerPool: BrokerPool): (Int, Int) = {
Expand Down

0 comments on commit aa101ad

Please sign in to comment.