photoprism/frontend/tests/acceptance/favorites.js

48 lines
1.4 KiB
JavaScript
Raw Normal View History

2019-06-04 11:02:28 +02:00
import { Selector } from 'testcafe';
import testcafeconfig from './testcafeconfig';
import Page from "./page-model";
2019-06-22 15:11:45 +02:00
import { RequestLogger } from 'testcafe';
const logger = RequestLogger( /http:\/\/localhost:2342\/api\/v1\/photos*/ , {
logResponseHeaders: true,
logResponseBody: true
});
2019-06-04 11:02:28 +02:00
fixture`Test favorites page`
2019-06-22 15:11:45 +02:00
.page `localhost:2342/favorites`
.requestHooks(logger);
2019-06-04 11:02:28 +02:00
const page = new Page();
test('Like photo', async t => {
const FavoritesCount = await Selector('.t-like.t-on').count;
2019-06-22 15:11:45 +02:00
logger.clear();
await t.navigateTo("../photos")
const request = await logger.requests[0].responseBody;
await page.likePhoto(5);
2019-06-22 15:11:45 +02:00
logger.clear();
await t.navigateTo("../favorites");
const request2 = await logger.requests[0].responseBody;
2019-06-22 15:11:45 +02:00
logger.clear();
const FavoritesCountAfterLike = await Selector('.t-like.t-on').count;
await t
.expect(FavoritesCountAfterLike).eql(FavoritesCount + 1)
2019-06-04 11:02:28 +02:00
.expect(Selector('div.v-image__image').visible).ok();
}),
2019-06-22 15:11:45 +02:00
test('Dislike photo', async t => {
const FavoritesCount = await Selector('.t-like.t-on').count;
2019-06-22 15:11:45 +02:00
await t
.click(Selector('.t-like.t-on'));
logger.clear();
await t.navigateTo("../favorites");
const request3 = await logger.requests[0].responseBody;
const FavoritesCountAfterDislike = await Selector('.t-like.t-on').count;
2019-06-22 15:11:45 +02:00
await t
.expect(FavoritesCountAfterDislike).eql(FavoritesCount - 1);
});