2022-12-20 22:13:37 +01:00
|
|
|
/*
|
|
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/// <reference types="cypress" />
|
|
|
|
|
2023-01-11 00:29:56 +01:00
|
|
|
import { HomeserverInstance } from "../../plugins/utils/homeserver";
|
2022-12-20 22:13:37 +01:00
|
|
|
import { UserCredentials } from "../../support/login";
|
|
|
|
|
|
|
|
const ROOM_NAME = "Integration Manager Test";
|
|
|
|
const USER_DISPLAY_NAME = "Alice";
|
|
|
|
|
|
|
|
const INTEGRATION_MANAGER_TOKEN = "DefinitelySecret_DoNotUseThisForReal";
|
|
|
|
const INTEGRATION_MANAGER_HTML = `
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<title>Fake Integration Manager</title>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<input type="text" id="target-room-id"/>
|
|
|
|
<input type="text" id="event-type"/>
|
|
|
|
<input type="text" id="state-key"/>
|
|
|
|
<button name="Send" id="send-action">Press to send action</button>
|
|
|
|
<button name="Close" id="close">Press to close</button>
|
|
|
|
<p id="message-response">No response</p>
|
|
|
|
<script>
|
|
|
|
document.getElementById("send-action").onclick = () => {
|
|
|
|
window.parent.postMessage(
|
|
|
|
{
|
|
|
|
action: "read_events",
|
|
|
|
room_id: document.getElementById("target-room-id").value,
|
|
|
|
type: document.getElementById("event-type").value,
|
|
|
|
state_key: JSON.parse(document.getElementById("state-key").value),
|
|
|
|
},
|
|
|
|
'*',
|
|
|
|
);
|
|
|
|
};
|
|
|
|
document.getElementById("close").onclick = () => {
|
|
|
|
window.parent.postMessage(
|
|
|
|
{
|
|
|
|
action: "close_scalar",
|
|
|
|
},
|
|
|
|
'*',
|
|
|
|
);
|
|
|
|
};
|
|
|
|
// Listen for a postmessage response
|
|
|
|
window.addEventListener("message", (event) => {
|
|
|
|
document.getElementById("message-response").innerText = JSON.stringify(event.data);
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
</body>
|
|
|
|
</html>
|
|
|
|
`;
|
|
|
|
|
|
|
|
function openIntegrationManager() {
|
2023-04-27 12:37:58 +02:00
|
|
|
cy.findByRole("button", { name: "Room info" }).click();
|
2022-12-20 22:13:37 +01:00
|
|
|
cy.get(".mx_RoomSummaryCard_appsGroup").within(() => {
|
2023-04-27 12:37:58 +02:00
|
|
|
cy.findByRole("button", { name: "Add widgets, bridges & bots" }).click();
|
2022-12-20 22:13:37 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function sendActionFromIntegrationManager(
|
|
|
|
integrationManagerUrl: string,
|
|
|
|
targetRoomId: string,
|
|
|
|
eventType: string,
|
|
|
|
stateKey: string | boolean,
|
|
|
|
) {
|
|
|
|
cy.accessIframe(`iframe[src*="${integrationManagerUrl}"]`).within(() => {
|
|
|
|
cy.get("#target-room-id").should("exist").type(targetRoomId);
|
|
|
|
cy.get("#event-type").should("exist").type(eventType);
|
|
|
|
cy.get("#state-key").should("exist").type(JSON.stringify(stateKey));
|
|
|
|
cy.get("#send-action").should("exist").click();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
describe("Integration Manager: Read Events", () => {
|
|
|
|
let testUser: UserCredentials;
|
2023-01-11 00:29:56 +01:00
|
|
|
let homeserver: HomeserverInstance;
|
2022-12-20 22:13:37 +01:00
|
|
|
let integrationManagerUrl: string;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
cy.serveHtmlFile(INTEGRATION_MANAGER_HTML).then((url) => {
|
|
|
|
integrationManagerUrl = url;
|
|
|
|
});
|
2023-01-11 00:29:56 +01:00
|
|
|
cy.startHomeserver("default").then((data) => {
|
|
|
|
homeserver = data;
|
2022-12-20 22:13:37 +01:00
|
|
|
|
2023-01-11 00:29:56 +01:00
|
|
|
cy.initTestUser(homeserver, USER_DISPLAY_NAME, () => {
|
2022-12-20 22:13:37 +01:00
|
|
|
cy.window().then((win) => {
|
|
|
|
win.localStorage.setItem("mx_scalar_token", INTEGRATION_MANAGER_TOKEN);
|
|
|
|
win.localStorage.setItem(`mx_scalar_token_at_${integrationManagerUrl}`, INTEGRATION_MANAGER_TOKEN);
|
|
|
|
});
|
|
|
|
}).then((user) => {
|
|
|
|
testUser = user;
|
|
|
|
});
|
|
|
|
|
|
|
|
cy.setAccountData("m.widgets", {
|
|
|
|
"m.integration_manager": {
|
|
|
|
content: {
|
|
|
|
type: "m.integration_manager",
|
|
|
|
name: "Integration Manager",
|
|
|
|
url: integrationManagerUrl,
|
|
|
|
data: {
|
|
|
|
api_url: integrationManagerUrl,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
id: "integration-manager",
|
|
|
|
},
|
|
|
|
}).as("integrationManager");
|
|
|
|
|
|
|
|
// Succeed when checking the token is valid
|
|
|
|
cy.intercept(`${integrationManagerUrl}/account?scalar_token=${INTEGRATION_MANAGER_TOKEN}*`, (req) => {
|
|
|
|
req.continue((res) => {
|
|
|
|
return res.send(200, {
|
|
|
|
user_id: testUser.userId,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
cy.createRoom({
|
|
|
|
name: ROOM_NAME,
|
|
|
|
}).as("roomId");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
2023-01-11 00:29:56 +01:00
|
|
|
cy.stopHomeserver(homeserver);
|
2022-12-20 22:13:37 +01:00
|
|
|
cy.stopWebServers();
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should read a state event by state key", () => {
|
|
|
|
cy.all([cy.get<string>("@roomId"), cy.get<{}>("@integrationManager")]).then(([roomId]) => {
|
|
|
|
cy.viewRoomByName(ROOM_NAME);
|
|
|
|
|
|
|
|
const eventType = "io.element.integrations.installations";
|
|
|
|
const eventContent = {
|
|
|
|
foo: "bar",
|
|
|
|
};
|
|
|
|
const stateKey = "state-key-123";
|
|
|
|
|
|
|
|
// Send a state event
|
|
|
|
cy.getClient()
|
|
|
|
.then(async (client) => {
|
|
|
|
return await client.sendStateEvent(roomId, eventType, eventContent, stateKey);
|
|
|
|
})
|
|
|
|
.then((event) => {
|
|
|
|
openIntegrationManager();
|
|
|
|
|
|
|
|
// Read state events
|
|
|
|
sendActionFromIntegrationManager(integrationManagerUrl, roomId, eventType, stateKey);
|
|
|
|
|
|
|
|
// Check the response
|
|
|
|
cy.accessIframe(`iframe[src*="${integrationManagerUrl}"]`).within(() => {
|
|
|
|
cy.get("#message-response")
|
|
|
|
.should("include.text", event.event_id)
|
|
|
|
.should("include.text", `"content":${JSON.stringify(eventContent)}`);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should read a state event with empty state key", () => {
|
|
|
|
cy.all([cy.get<string>("@roomId"), cy.get<{}>("@integrationManager")]).then(([roomId]) => {
|
|
|
|
cy.viewRoomByName(ROOM_NAME);
|
|
|
|
|
|
|
|
const eventType = "io.element.integrations.installations";
|
|
|
|
const eventContent = {
|
|
|
|
foo: "bar",
|
|
|
|
};
|
|
|
|
const stateKey = "";
|
|
|
|
|
|
|
|
// Send a state event
|
|
|
|
cy.getClient()
|
|
|
|
.then(async (client) => {
|
|
|
|
return await client.sendStateEvent(roomId, eventType, eventContent, stateKey);
|
|
|
|
})
|
|
|
|
.then((event) => {
|
|
|
|
openIntegrationManager();
|
|
|
|
|
|
|
|
// Read state events
|
|
|
|
sendActionFromIntegrationManager(integrationManagerUrl, roomId, eventType, stateKey);
|
|
|
|
|
|
|
|
// Check the response
|
|
|
|
cy.accessIframe(`iframe[src*="${integrationManagerUrl}"]`).within(() => {
|
|
|
|
cy.get("#message-response")
|
|
|
|
.should("include.text", event.event_id)
|
|
|
|
.should("include.text", `"content":${JSON.stringify(eventContent)}`);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should read state events with any state key", () => {
|
|
|
|
cy.all([cy.get<string>("@roomId"), cy.get<{}>("@integrationManager")]).then(([roomId]) => {
|
|
|
|
cy.viewRoomByName(ROOM_NAME);
|
|
|
|
|
|
|
|
const eventType = "io.element.integrations.installations";
|
|
|
|
|
|
|
|
const stateKey1 = "state-key-123";
|
|
|
|
const eventContent1 = {
|
|
|
|
foo1: "bar1",
|
|
|
|
};
|
|
|
|
const stateKey2 = "state-key-456";
|
|
|
|
const eventContent2 = {
|
|
|
|
foo2: "bar2",
|
|
|
|
};
|
|
|
|
const stateKey3 = "state-key-789";
|
|
|
|
const eventContent3 = {
|
|
|
|
foo3: "bar3",
|
|
|
|
};
|
|
|
|
|
|
|
|
// Send state events
|
|
|
|
cy.getClient()
|
|
|
|
.then(async (client) => {
|
|
|
|
return Promise.all([
|
|
|
|
client.sendStateEvent(roomId, eventType, eventContent1, stateKey1),
|
|
|
|
client.sendStateEvent(roomId, eventType, eventContent2, stateKey2),
|
|
|
|
client.sendStateEvent(roomId, eventType, eventContent3, stateKey3),
|
|
|
|
]);
|
|
|
|
})
|
|
|
|
.then((events) => {
|
|
|
|
openIntegrationManager();
|
|
|
|
|
|
|
|
// Read state events
|
|
|
|
sendActionFromIntegrationManager(
|
|
|
|
integrationManagerUrl,
|
|
|
|
roomId,
|
|
|
|
eventType,
|
|
|
|
true, // Any state key
|
|
|
|
);
|
|
|
|
|
|
|
|
// Check the response
|
|
|
|
cy.accessIframe(`iframe[src*="${integrationManagerUrl}"]`).within(() => {
|
|
|
|
cy.get("#message-response")
|
|
|
|
.should("include.text", events[0].event_id)
|
|
|
|
.should("include.text", `"content":${JSON.stringify(eventContent1)}`)
|
|
|
|
.should("include.text", events[1].event_id)
|
|
|
|
.should("include.text", `"content":${JSON.stringify(eventContent2)}`)
|
|
|
|
.should("include.text", events[2].event_id)
|
|
|
|
.should("include.text", `"content":${JSON.stringify(eventContent3)}`);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it("should fail to read an event type which is not allowed", () => {
|
|
|
|
cy.all([cy.get<string>("@roomId"), cy.get<{}>("@integrationManager")]).then(([roomId]) => {
|
|
|
|
cy.viewRoomByName(ROOM_NAME);
|
|
|
|
|
|
|
|
const eventType = "com.example.event";
|
|
|
|
const stateKey = "";
|
|
|
|
|
|
|
|
openIntegrationManager();
|
|
|
|
|
|
|
|
// Read state events
|
|
|
|
sendActionFromIntegrationManager(integrationManagerUrl, roomId, eventType, stateKey);
|
|
|
|
|
|
|
|
// Check the response
|
|
|
|
cy.accessIframe(`iframe[src*="${integrationManagerUrl}"]`).within(() => {
|
|
|
|
cy.get("#message-response").should("include.text", "Failed to read events");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|