Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,11 @@ class SplitwellFrontendIntegrationTest
with SplitwellFrontendTestUtil
with FrontendLoginUtil {

private def withFrontEndStep[A](frontend: String, step: String)(body: WebDriverType => A): A =
withClue(s"[frontend=$frontend step=$step]") {
withFrontEnd(frontend)(body)
}

override def environmentDefinition: SpliceEnvironmentDefinition =
EnvironmentDefinition
.simpleTopology1Sv(this.getClass.getSimpleName)
Expand Down Expand Up @@ -54,43 +59,44 @@ class SplitwellFrontendIntegrationTest

bobWalletClient.tap(walletAmuletToUsd(550))

val invite = withFrontEnd("aliceSplitwell") { implicit webDriver =>
val invite = withFrontEndStep("aliceSplitwell", "create-invite") { implicit webDriver =>
login(aliceSplitwellUIPort, aliceDamlUser)
createGroupAndInviteLink(groupName)
}

withFrontEnd("bobSplitwell") { implicit webDriver =>
withFrontEndStep("bobSplitwell", "request-membership") { implicit webDriver =>
login(bobSplitwellUIPort, bobDamlUser)
requestGroupMembership(invite)
}

withFrontEnd("aliceSplitwell") { implicit webDriver =>
withFrontEndStep("aliceSplitwell", "click-add-user-link") { implicit webDriver =>
eventuallyClickOn(className("add-user-link"))
}

withFrontEnd("charlieSplitwell") { implicit webDriver =>
withFrontEndStep("charlieSplitwell", "request-membership") { implicit webDriver =>
login(charlieSplitwellUIPort, charlieDamlUser)
requestGroupMembership(invite)
}

withFrontEnd("aliceSplitwell") { implicit webDriver =>
eventuallyClickOn(className("add-user-link"))
eventually() {
findAll(className("balances-table-row")).toSeq should have length 2
}
withFrontEndStep("aliceSplitwell", "click-add-user-link-and-check-balance-table-length") {
implicit webDriver =>
eventuallyClickOn(className("add-user-link"))
eventually() {
findAll(className("balances-table-row")).toSeq should have length 2
}

inside(eventuallyFind(className("enter-payment-amount-field"))) { case Some(field) =>
field.underlying.click()
reactTextInput(field).value = "1200.0"
}
inside(eventuallyFind(className("enter-payment-description-field"))) { case Some(field) =>
field.underlying.click()
reactTextInput(field).value = "Team lunch"
}
eventuallyClickOn(className("enter-payment-link"))
inside(eventuallyFind(className("enter-payment-amount-field"))) { case Some(field) =>
field.underlying.click()
reactTextInput(field).value = "1200.0"
}
inside(eventuallyFind(className("enter-payment-description-field"))) { case Some(field) =>
field.underlying.click()
reactTextInput(field).value = "Team lunch"
}
eventuallyClickOn(className("enter-payment-link"))
}

withFrontEnd("charlieSplitwell") { implicit webDriver =>
withFrontEndStep("charlieSplitwell", "enter-payment-info") { implicit webDriver =>
inside(eventuallyFind(className("enter-payment-amount-field"))) { case Some(field) =>
field.underlying.click()
reactTextInput(field).value = "333.0"
Expand All @@ -102,7 +108,7 @@ class SplitwellFrontendIntegrationTest
eventuallyClickOn(className("enter-payment-link"))
}

withFrontEnd("bobSplitwell") { implicit webDriver =>
withFrontEndStep("bobSplitwell", "settle-debts-and-verify") { implicit webDriver =>
eventually() {
inside(findAll(className("balances-table-row")).toSeq) {
case Seq(r1, r2) => // Need to sync here on the actual values (size not enough)
Expand Down Expand Up @@ -205,25 +211,26 @@ class SplitwellFrontendIntegrationTest
val bobAns = expectedAns(bobUserParty, bobEntryName)
bobWalletClient.tap(walletAmuletToUsd(510))

val invite = withFrontEnd("aliceSplitwell") { implicit webDriver =>
val invite = withFrontEndStep("aliceSplitwell", "create-invite") { implicit webDriver =>
login(aliceSplitwellUIPort, aliceDamlUser)
createGroupAndInviteLink(groupName)
}

withFrontEnd("bobSplitwell") { implicit webDriver =>
withFrontEndStep("bobSplitwell", "request-membership") { implicit webDriver =>
login(bobSplitwellUIPort, bobDamlUser)
requestGroupMembership(invite)
}

withFrontEnd("aliceSplitwell") { implicit webDriver =>
eventuallyClickOn(className("add-user-link"))
eventually() {
findAll(className("balances-table-row")).toSeq should have length 1
}
addTeamLunch(1000)
withFrontEndStep("aliceSplitwell", "click-add-user-link-and-check-balance-table-length") {
implicit webDriver =>
eventuallyClickOn(className("add-user-link"))
eventually() {
findAll(className("balances-table-row")).toSeq should have length 1
}
addTeamLunch(1000)
}

withFrontEnd("bobSplitwell") { implicit webDriver =>
withFrontEndStep("bobSplitwell", "enter-payment-accept-verify") { implicit webDriver =>
enterSplitwellPayment(aliceEntryName, aliceUserParty, 500)

// Bob is redirected to wallet ..
Expand Down Expand Up @@ -271,7 +278,7 @@ class SplitwellFrontendIntegrationTest
)
}

withFrontEnd("bobSplitwell") { implicit webDriver =>
withFrontEndStep("bobSplitwell", "error-on-unknown-party") { implicit webDriver =>
val errorMsg = "is not part of the group"
loggerFactory.assertLoggedWarningsAndErrorsSeq(
enterSplitwellPayment("unknown::abc", PartyId.tryFromProtoPrimitive("unknown::abc"), 42),
Expand All @@ -292,32 +299,33 @@ class SplitwellFrontendIntegrationTest
onboardWalletUser(charlieWalletClient, charlieValidator)

// Alice creates three groups - abc, ab, ac
val (invite1, invite2, invite3) = withFrontEnd("aliceSplitwell") { implicit webDriver =>
login(aliceSplitwellUIPort, aliceDamlUser)
val (invite1, invite2, invite3) = withFrontEndStep("aliceSplitwell", "create-three-groups") {
implicit webDriver =>
login(aliceSplitwellUIPort, aliceDamlUser)

val invite1 = createGroupAndInviteLink("group-abc")
val invite2 = createGroupAndInviteLink("group-ab")
val invite3 = createGroupAndInviteLink("group-ac")
val invite1 = createGroupAndInviteLink("group-abc")
val invite2 = createGroupAndInviteLink("group-ab")
val invite3 = createGroupAndInviteLink("group-ac")

(invite1, invite2, invite3)
(invite1, invite2, invite3)
}

// Bob requests to join groups abc and ab
withFrontEnd("bobSplitwell") { implicit webDriver =>
withFrontEndStep("bobSplitwell", "request-membership-abc-ab") { implicit webDriver =>
login(bobSplitwellUIPort, bobDamlUser)
requestGroupMembership(invite1)
requestGroupMembership(invite2)
}

// Charlie requests to join groups abc and ac
withFrontEnd("charlieSplitwell") { implicit webDriver =>
withFrontEndStep("charlieSplitwell", "request-membership-abc-ac") { implicit webDriver =>
login(charlieSplitwellUIPort, charlieDamlUser)
requestGroupMembership(invite1)
requestGroupMembership(invite3)
}

// Alice accepts all requests
withFrontEnd("aliceSplitwell") { implicit webDriver =>
withFrontEndStep("aliceSplitwell", "accept-all-membership-requests") { implicit webDriver =>
eventually(timeUntilSuccess = 20.minute) {
findAll(
className("add-user-link")
Expand All @@ -342,7 +350,7 @@ class SplitwellFrontendIntegrationTest
}
}

withFrontEnd("bobSplitwell") { implicit webDriver =>
withFrontEndStep("bobSplitwell", "verify-bob-groups") { implicit webDriver =>
eventually() {
findAll(className("group-entry")) should have length 2
val groups = findAll(className("group-entry")).toSeq
Expand All @@ -356,7 +364,7 @@ class SplitwellFrontendIntegrationTest
)
}
}
withFrontEnd("charlieSplitwell") { implicit webDriver =>
withFrontEndStep("charlieSplitwell", "verify-charlie-groups") { implicit webDriver =>
eventually() {
findAll(className("group-entry")) should have length 2
val groups = findAll(className("group-entry")).toSeq
Expand Down
Loading