mirror of
https://github.com/wassname/talk.git
synced 2026-06-30 03:31:01 +08:00
139 lines
3.8 KiB
JavaScript
139 lines
3.8 KiB
JavaScript
module.exports = {
|
|
|
|
before: (client) => {
|
|
client.resizeWindow(1600, 1200);
|
|
},
|
|
|
|
afterEach: (client, done) => {
|
|
if (client.currentTest.results.failed) {
|
|
throw new Error('Test Case failed, skipping all the rest');
|
|
}
|
|
done();
|
|
},
|
|
|
|
after: (client) => {
|
|
client.end();
|
|
},
|
|
'user logs in': (client) => {
|
|
const {testData: {user}} = client.globals;
|
|
const embedStream = client.page.embedStream();
|
|
const comments = client.page.embedStream().section.comments;
|
|
|
|
embedStream
|
|
.navigate()
|
|
.ready();
|
|
|
|
comments
|
|
.openLoginPopup((popup) => popup.login(user));
|
|
},
|
|
'user posts comment': (client) => {
|
|
const comments = client.page.embedStream().section.comments;
|
|
const {testData: {comment}} = client.globals;
|
|
|
|
comments
|
|
.waitForElementVisible('@commentBoxTextarea')
|
|
.setValue('@commentBoxTextarea', comment.body)
|
|
.waitForElementVisible('@commentBoxPostButton')
|
|
.click('@commentBoxPostButton')
|
|
.waitForElementVisible('@firstCommentContent')
|
|
.getText('@firstCommentContent', (result) => {
|
|
comments.assert.equal(result.value, comment.body);
|
|
});
|
|
},
|
|
'user logs out': (client) => {
|
|
const embedStream = client.page.embedStream();
|
|
const comments = embedStream.section.comments;
|
|
|
|
comments
|
|
.logout();
|
|
},
|
|
'admin logs in': (client) => {
|
|
const adminPage = client.page.admin();
|
|
const {testData: {admin}} = client.globals;
|
|
|
|
adminPage.navigateAndLogin(admin);
|
|
},
|
|
'navigate to the embed stream': (client) => {
|
|
const embedStream = client.page.embedStream();
|
|
|
|
embedStream
|
|
.navigate()
|
|
.ready();
|
|
},
|
|
'admin reports comment': (client) => {
|
|
const embedStream = client.page.embedStream();
|
|
const comments = embedStream.section.comments;
|
|
|
|
comments
|
|
.waitForElementVisible('@firstComment')
|
|
.waitForElementVisible('@flagButton')
|
|
.click('@flagButton');
|
|
|
|
comments.section.flag
|
|
.waitForElementVisible('@flagCommentRadio')
|
|
.click('@flagCommentRadio')
|
|
.waitForElementVisible('@continueButton')
|
|
.click('@continueButton')
|
|
.waitForElementVisible('@spamCommentRadio')
|
|
.click('@spamCommentRadio')
|
|
.click('@continueButton')
|
|
.waitForElementVisible('@popUpText')
|
|
.click('@continueButton');
|
|
},
|
|
'admin suspends user': (client) => {
|
|
const adminPage = client.page.admin();
|
|
const moderate = adminPage.section.moderate;
|
|
|
|
adminPage
|
|
.navigate()
|
|
.ready()
|
|
.goToModerate();
|
|
|
|
moderate
|
|
.waitForElementVisible('@comment')
|
|
.waitForElementVisible('@commentActionMenu')
|
|
.waitForElementVisible('@actionMenuButton')
|
|
.click('@actionMenuButton')
|
|
.waitForElementVisible('@actionItemSuspendUser')
|
|
.click('@actionItemSuspendUser');
|
|
|
|
adminPage
|
|
.waitForElementVisible('@suspendUserDialog')
|
|
.waitForElementVisible('@suspendUserConfirmButton')
|
|
.click('@suspendUserConfirmButton')
|
|
.waitForElementVisible('@supendUserSendButton')
|
|
.click('@supendUserSendButton');
|
|
|
|
adminPage
|
|
.waitForElementVisible('@toast')
|
|
.waitForElementVisible('@toastClose')
|
|
.click('@toastClose');
|
|
|
|
},
|
|
'admin logs out': (client) => {
|
|
const adminPage = client.page.admin();
|
|
|
|
adminPage
|
|
.logout();
|
|
},
|
|
'user logs in (2)': (client) => {
|
|
const {testData: {user}} = client.globals;
|
|
const embedStream = client.page.embedStream();
|
|
const comments = client.page.embedStream().section.comments;
|
|
|
|
embedStream
|
|
.navigate()
|
|
.ready();
|
|
|
|
comments
|
|
.openLoginPopup((popup) => popup.login(user));
|
|
},
|
|
'user account is suspended, should see restricted message box': (client) => {
|
|
const embedStream = client.page.embedStream();
|
|
const comments = embedStream.section.comments;
|
|
|
|
comments
|
|
.waitForElementVisible('@restrictedMessageBox');
|
|
},
|
|
};
|