-import { VideoWatchPage } from './po/video-watch.po'
-import { VideoUploadPage } from './po/video-upload.po'
import { LoginPage } from './po/login.po'
-import { browser } from 'protractor'
+import { MyAccountPage } from './po/my-account'
+import { PlayerPage } from './po/player.po'
+import { VideoUpdatePage } from './po/video-update.po'
+import { VideoUploadPage } from './po/video-upload.po'
+import { VideoWatchPage } from './po/video-watch.po'
+import { browserSleep, go, isIOS, isMobileDevice, isSafari } from './utils'
+
+function isUploadUnsupported () {
+ if (isMobileDevice() || isSafari()) {
+ console.log('Skipping because we are on a real device or Safari and BrowserStack does not support file upload.')
+ return true
+ }
+
+ return false
+}
describe('Videos workflow', () => {
let videoWatchPage: VideoWatchPage
- let pageUploadPage: VideoUploadPage
+ let videoUploadPage: VideoUploadPage
+ let videoUpdatePage: VideoUpdatePage
+ let myAccountPage: MyAccountPage
let loginPage: LoginPage
- const videoName = new Date().getTime() + ' video'
- let isMobileDevice = false
- let isSafari = false
+ let playerPage: PlayerPage
+
+ let videoName = Math.random() + ' video'
+ const video2Name = Math.random() + ' second video'
+ const playlistName = Math.random() + ' playlist'
+ let videoWatchUrl: string
+
+ before(async () => {
+ if (isIOS()) {
+ console.log('iOS detected')
+ } else if (isMobileDevice()) {
+ console.log('Android detected.')
+ } else if (isSafari()) {
+ console.log('Safari detected.')
+ }
+
+ if (isUploadUnsupported()) return
+
+ await browser.waitUntil(async () => {
+ await go('/')
+ await browserSleep(500)
+
+ return $('<my-app>').isDisplayed()
+ }, { timeout: 20 * 1000 })
+ })
beforeEach(async () => {
videoWatchPage = new VideoWatchPage()
- pageUploadPage = new VideoUploadPage()
+ videoUploadPage = new VideoUploadPage()
+ videoUpdatePage = new VideoUpdatePage()
+ myAccountPage = new MyAccountPage()
loginPage = new LoginPage()
+ playerPage = new PlayerPage()
- const caps = await browser.getCapabilities()
- isMobileDevice = caps.get('realMobile') === 'true' || caps.get('realMobile') === true
- isSafari = caps.get('browserName') && caps.get('browserName').toLowerCase() === 'safari'
-
- if (isMobileDevice) {
- console.log('Mobile device detected.')
- }
-
- if (isSafari) {
- console.log('Safari detected.')
+ if (!isMobileDevice()) {
+ await browser.maximizeWindow()
}
})
- it('Should log in', () => {
- if (isMobileDevice || isSafari) {
+ it('Should log in', async () => {
+ if (isMobileDevice() || isSafari()) {
console.log('Skipping because we are on a real device or Safari and BrowserStack does not support file upload.')
return
}
})
it('Should upload a video', async () => {
- if (isMobileDevice || isSafari) {
- console.log('Skipping because we are on a real device or Safari and BrowserStack does not support file upload.')
- return
- }
+ if (isUploadUnsupported()) return
- await pageUploadPage.navigateTo()
+ await videoUploadPage.navigateTo()
- await pageUploadPage.uploadVideo()
- return pageUploadPage.validSecondUploadStep(videoName)
+ await videoUploadPage.uploadVideo()
+ return videoUploadPage.validSecondUploadStep(videoName)
})
it('Should list videos', async () => {
- await videoWatchPage.goOnVideosList(isMobileDevice, isSafari)
+ await videoWatchPage.goOnVideosList(isMobileDevice(), isSafari())
- if (isMobileDevice || isSafari) {
- console.log('Skipping because we are on a real device or Safari and BrowserStack does not support file upload.')
- return
- }
+ if (isUploadUnsupported()) return
- const videoNames = videoWatchPage.getVideosListName()
+ const videoNames = await videoWatchPage.getVideosListName()
expect(videoNames).toContain(videoName)
})
it('Should go on video watch page', async () => {
let videoNameToExcept = videoName
- if (isMobileDevice || isSafari) videoNameToExcept = await videoWatchPage.clickOnFirstVideo()
- else await videoWatchPage.clickOnVideo(videoName)
+ if (isMobileDevice() || isSafari()) {
+ await go('https://peertube2.cpy.re/w/122d093a-1ede-43bd-bd34-59d2931ffc5e')
+ videoNameToExcept = 'E2E tests'
+ } else {
+ await videoWatchPage.clickOnVideo(videoName)
+ }
- return videoWatchPage.waitWatchVideoName(videoNameToExcept, isMobileDevice, isSafari)
+ return videoWatchPage.waitWatchVideoName(videoNameToExcept, isMobileDevice(), isSafari())
})
it('Should play the video', async () => {
- await videoWatchPage.playAndPauseVideo(true, isMobileDevice)
- expect(videoWatchPage.getWatchVideoPlayerCurrentTime()).toBeGreaterThanOrEqual(2)
+ videoWatchUrl = await browser.getUrl()
+
+ await playerPage.playAndPauseVideo(true)
+ expect(await playerPage.getWatchVideoPlayerCurrentTime()).toBeGreaterThanOrEqual(2)
})
it('Should watch the associated embed video', async () => {
- await browser.waitForAngularEnabled(false)
-
await videoWatchPage.goOnAssociatedEmbed()
- await videoWatchPage.playAndPauseVideo(false, isMobileDevice)
- expect(videoWatchPage.getWatchVideoPlayerCurrentTime()).toBeGreaterThanOrEqual(2)
-
- await browser.waitForAngularEnabled(true)
+ await playerPage.playAndPauseVideo(false)
+ expect(await playerPage.getWatchVideoPlayerCurrentTime()).toBeGreaterThanOrEqual(2)
})
it('Should watch the p2p media loader embed video', async () => {
- await browser.waitForAngularEnabled(false)
-
await videoWatchPage.goOnP2PMediaLoaderEmbed()
- await videoWatchPage.playAndPauseVideo(false, isMobileDevice)
- expect(videoWatchPage.getWatchVideoPlayerCurrentTime()).toBeGreaterThanOrEqual(2)
+ await playerPage.playAndPauseVideo(false)
+ expect(await playerPage.getWatchVideoPlayerCurrentTime()).toBeGreaterThanOrEqual(2)
+ })
+
+ it('Should update the video', async () => {
+ if (isUploadUnsupported()) return
+
+ await go(videoWatchUrl)
+
+ await videoWatchPage.clickOnUpdate()
+
+ videoName += ' updated'
+ await videoUpdatePage.updateName(videoName)
+
+ await videoUpdatePage.validUpdate()
+
+ const name = await videoWatchPage.getVideoName()
+ expect(name).toEqual(videoName)
+ })
+
+ it('Should add the video in my playlist', async () => {
+ if (isUploadUnsupported()) return
+
+ await videoWatchPage.clickOnSave()
+
+ await videoWatchPage.createPlaylist(playlistName)
+
+ await videoWatchPage.saveToPlaylist(playlistName)
+ await browser.pause(5000)
+
+ await videoUploadPage.navigateTo()
+
+ await videoUploadPage.uploadVideo()
+ await videoUploadPage.validSecondUploadStep(video2Name)
+
+ await videoWatchPage.clickOnSave()
+ await videoWatchPage.saveToPlaylist(playlistName)
+ })
+
+ it('Should have the playlist in my account', async () => {
+ if (isUploadUnsupported()) return
+
+ await myAccountPage.navigateToMyPlaylists()
+
+ const videosNumberText = await myAccountPage.getPlaylistVideosText(playlistName)
+ expect(videosNumberText).toEqual('2 videos')
+
+ await myAccountPage.clickOnPlaylist(playlistName)
+
+ const count = await myAccountPage.countTotalPlaylistElements()
+ expect(count).toEqual(2)
+ })
+
+ it('Should watch the playlist', async () => {
+ if (isUploadUnsupported()) return
+
+ await myAccountPage.playPlaylist()
+
+ await videoWatchPage.waitUntilVideoName(video2Name, 30 * 1000)
+ })
+
+ it('Should watch the webtorrent playlist in the embed', async () => {
+ if (isUploadUnsupported()) return
+
+ const accessToken = await browser.execute(`return window.localStorage.getItem('access_token');`)
+ const refreshToken = await browser.execute(`return window.localStorage.getItem('refresh_token');`)
+
+ await myAccountPage.goOnAssociatedPlaylistEmbed()
+
+ await playerPage.waitUntilPlayerWrapper()
+
+ console.log('Will set %s and %s tokens in local storage.', accessToken, refreshToken)
+
+ await browser.execute(`window.localStorage.setItem('access_token', '${accessToken}');`)
+ await browser.execute(`window.localStorage.setItem('refresh_token', '${refreshToken}');`)
+ await browser.execute(`window.localStorage.setItem('token_type', 'Bearer');`)
+
+ await browser.refresh()
+
+ await playerPage.playVideo()
+
+ await playerPage.waitUntilPlaylistInfo('2/2', 30 * 1000)
+ })
+
+ it('Should watch the HLS playlist in the embed', async () => {
+ await videoWatchPage.goOnP2PMediaLoaderPlaylistEmbed()
+
+ await playerPage.playVideo()
+
+ await playerPage.waitUntilPlaylistInfo('2/2', 30 * 1000)
+ })
+
+ it('Should delete the video 2', async () => {
+ if (isUploadUnsupported()) return
+
+ // Go to the dev website
+ await go(videoWatchUrl)
+
+ await myAccountPage.navigateToMyVideos()
+
+ await myAccountPage.removeVideo(video2Name)
+ await myAccountPage.validRemove()
+
+ await browser.waitUntil(async () => {
+ const count = await myAccountPage.countVideos([ videoName, video2Name ])
+
+ return count === 1
+ })
+ })
+
+ it('Should delete the first video', async () => {
+ if (isUploadUnsupported()) return
- await browser.waitForAngularEnabled(true)
+ await myAccountPage.removeVideo(videoName)
+ await myAccountPage.validRemove()
})
})