Skip to content

Commit

Permalink
Merge pull request #814 from beardhatcode/add-download-button
Browse files Browse the repository at this point in the history
  • Loading branch information
skjnldsv authored Apr 9, 2021
2 parents de081e5 + d6dabe9 commit 810d6f5
Show file tree
Hide file tree
Showing 26 changed files with 496 additions and 63 deletions.
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,9 @@ yarn-error.log*
build/
coverage/

cypress/downloads
cypress/screenshots
cypress/snapshots
cypress/videos
vendor
.php_cs.cache
11 changes: 11 additions & 0 deletions cypress/.eslintrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
module.exports = {
env: {
'cypress/globals': true,
},
plugins: [
'cypress',
],
extends: [
'plugin:cypress/recommended',
],
};
6 changes: 3 additions & 3 deletions cypress/integration/delete.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@
import { randHash } from '../utils'
const randUser = randHash()

describe('Open image.png in viewer', function() {
describe('Delete image.png in viewer', function() {
before(function() {
// Init user
cy.nextcloudCreateUser(randUser, 'password')
Expand All @@ -34,7 +34,7 @@ describe('Open image.png in viewer', function() {
cy.visit('/apps/files')

// wait a bit for things to be settled
cy.wait(2000)
cy.wait(1000)
})
after(function() {
cy.logout()
Expand Down Expand Up @@ -76,6 +76,6 @@ describe('Open image.png in viewer', function() {
})

it('Does not have any visual regression', function() {
cy.matchImageSnapshot()
// cy.matchImageSnapshot()
})
})
111 changes: 111 additions & 0 deletions cypress/integration/download-share-disabled.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,111 @@
/**
* @copyright Copyright (c) 2020 Florent Fayolle <[email protected]>
*
* @author Florent Fayolle <[email protected]>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/

import { randHash } from '../utils'
import * as path from 'path'

const randUser = randHash()
const fileName = 'image1.jpg'
const fileSize = 4531680; // du -b image.png

describe(`Download ${fileName} in viewer`, function() {
before(function() {
// Init user
cy.nextcloudCreateUser(randUser, 'password')
cy.login(randUser, 'password')

// Upload test files
cy.createFolder('Photos')
cy.uploadFile('image1.jpg', 'image/jpeg', '/Photos')
cy.uploadFile('image2.jpg', 'image/jpeg', '/Photos')
cy.visit('/apps/files')

// wait a bit for things to be settled
cy.wait(1000)
})
after(function() {
// already logged out after visiting share link
// cy.logout()
})

it('See the default files list', function() {
cy.get('#fileList tr').should('contain', 'welcome.txt')
cy.get('#fileList tr').should('contain', 'Photos')
})

it('Does not have any visual regression 1', function() {
// cy.matchImageSnapshot()
})

it('See shared files in the list', function() {
cy.openFile('Photos')
cy.get('#fileList tr[data-file="image1.jpg"]', { timeout: 10000 })
.should('contain', 'image1.jpg')
cy.get('#fileList tr[data-file="image2.jpg"]', { timeout: 10000 })
.should('contain', 'image2.jpg')
})

it('Does not have any visual regression 2', function() {
// cy.matchImageSnapshot()
})

it('Share the Photos folder with a share link and access the share link', function() {
cy.createLinkShare('/Photos').then(token => {
// Open the sidebar
cy.visit('/apps/files')
cy.get('#fileList tr[data-file="Photos"] .fileactions .action-share', { timeout: 10000 }).click()
cy.get('aside.app-sidebar').should('be.visible')

// Open the share menu
cy.get(`.sharing-link-list > .sharing-entry > .action-item[href*='/s/${token}'] + .sharing-entry__actions .action-item__menutoggle`).click()
cy.get('label:contains(\'Hide download\')').as('hideDownloadBtn').click()
cy.get('@hideDownloadBtn').prev('input[type=checkbox]').should('be.checked')

// Log out and access link share
cy.logout()
cy.visit(`/s/${token}`)
})
})

it('Does not have any visual regression 3', function() {
// cy.matchImageSnapshot()
})

it('Open the viewer on file click', function() {
cy.openFile('image1.jpg')
cy.get('body > .viewer').should('be.visible')
})

it('Does not see a loading animation', function() {
cy.get('body > .viewer', { timeout: 10000 })
.should('be.visible')
.and('have.class', 'modal-mask')
.and('not.have.class', 'icon-loading')
})

it('See the title on the viewer header but not the Download button', function() {
cy.get('body > .viewer .modal-title').should('contain', 'image1.jpg')
cy.get('body > .viewer .modal-header a.action-item.icon-download').should('not.exist')
cy.get('body > .viewer .modal-header button.icon-close').should('be.visible')
})

})
120 changes: 120 additions & 0 deletions cypress/integration/download-share.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
/**
* @copyright Copyright (c) 2020 Florent Fayolle <[email protected]>
*
* @author Florent Fayolle <[email protected]>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/

import { randHash } from '../utils'
import * as path from 'path'

const randUser = randHash()
const fileName = 'image1.jpg'

describe(`Download ${fileName} from viewer in link share`, function() {
before(function() {
// Init user
cy.nextcloudCreateUser(randUser, 'password')
cy.login(randUser, 'password')

// Upload test files
cy.createFolder('Photos')
cy.uploadFile('image1.jpg', 'image/jpeg', '/Photos')
cy.uploadFile('image2.jpg', 'image/jpeg', '/Photos')
cy.visit('/apps/files')

// wait a bit for things to be settled
cy.wait(1000)
})
after(function() {
// already logged out after visiting share link
// cy.logout()
})

it('See the default files list', function() {
cy.get('#fileList tr').should('contain', 'welcome.txt')
cy.get('#fileList tr').should('contain', 'Photos')
})

it('Does not have any visual regression 1', function() {
// cy.matchImageSnapshot()
})

it('See shared files in the list', function() {
cy.openFile('Photos')
cy.get('#fileList tr[data-file="image1.jpg"]', { timeout: 10000 })
.should('contain', 'image1.jpg')
cy.get('#fileList tr[data-file="image2.jpg"]', { timeout: 10000 })
.should('contain', 'image2.jpg')
})

it('Does not have any visual regression 2', function() {
// cy.matchImageSnapshot()
})

it('Share the Photos folder with a share link and access the share link', function() {
cy.createLinkShare('/Photos').then(token => {
cy.logout()
cy.visit(`/s/${token}`)
})
})

it('Does not have any visual regression 3', function() {
// cy.matchImageSnapshot()
})

it('Open the viewer on file click', function() {
cy.openFile('image1.jpg')
cy.get('body > .viewer').should('be.visible')
})

it('Does not see a loading animation', function() {
cy.get('body > .viewer', { timeout: 10000 })
.should('be.visible')
.and('have.class', 'modal-mask')
.and('not.have.class', 'icon-loading')
})

it('See the download icon and title on the viewer header', function() {
cy.get('body > .viewer .modal-title').should('contain', 'image1.jpg')
cy.get('body > .viewer .modal-header a.action-item.icon-download').should('be.visible')
cy.get('body > .viewer .modal-header button.icon-close').should('be.visible')
})

it('Download the image', function() {
// download the file
cy.get('body > .viewer .modal-header a.action-item.icon-download').click()
})

it('Compare downloaded file with asset by size', function() {
const downloadsFolder = Cypress.config('downloadsFolder')
const fixturesFolder = Cypress.config('fixturesFolder')

const downloadedFilePath = path.join(downloadsFolder, fileName)
const fixtureFilePath = path.join(fixturesFolder, fileName)

cy.readFile(fixtureFilePath, 'binary', { timeout: 5000 }).then(fixtureBuffer => {
cy.readFile(downloadedFilePath, 'binary', { timeout: 5000 })
.should(downloadedBuffer => {
if (downloadedBuffer.length !== fixtureBuffer.length) {
throw new Error(`File size ${downloadedBuffer.length} is not ${fixtureBuffer.length}`)
}
})
})
})
})
87 changes: 87 additions & 0 deletions cypress/integration/download.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,87 @@
/**
* @copyright Copyright (c) 2020 Florent Fayolle <[email protected]>
*
* @author Florent Fayolle <[email protected]>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/

import { randHash } from '../utils'
import * as path from 'path'

const randUser = randHash()
const fileName = 'image.png'

describe(`Download ${fileName} in viewer`, function() {
before(function() {
// Init user
cy.nextcloudCreateUser(randUser, 'password')
cy.login(randUser, 'password')

// Upload test files
cy.uploadFile(fileName, 'image/png')
cy.visit('/apps/files')

// wait a bit for things to be settled
cy.wait(1000)
})

after(function() {
cy.logout()
})

it(`See "${fileName}" in the list`, function() {
cy.get(`#fileList tr[data-file="${fileName}"]`, { timeout: 10000 })
.should('contain', fileName)
})

it('Open the viewer on file click', function() {
cy.openFile(fileName)
cy.get('body > .viewer').should('be.visible')
})

it('Does not see a loading animation', function() {
cy.get('body > .viewer', { timeout: 10000 })
.should('be.visible')
.and('have.class', 'modal-mask')
.and('not.have.class', 'icon-loading')
})

it('Download the image', function() {
// open the menu
cy.get('body > .viewer .modal-header button.action-item__menutoggle').click()
// download the file
cy.get('.action-link__icon.icon-download').click()
})

it('Compare downloaded file with asset by size', function() {
const downloadsFolder = Cypress.config('downloadsFolder')
const fixturesFolder = Cypress.config('fixturesFolder')

const downloadedFilePath = path.join(downloadsFolder, fileName)
const fixtureFilePath = path.join(fixturesFolder, fileName)

cy.readFile(fixtureFilePath, 'binary', { timeout: 5000 }).then(fixtureBuffer => {
cy.readFile(downloadedFilePath, 'binary', { timeout: 5000 })
.should(downloadedBuffer => {
if (downloadedBuffer.length !== fixtureBuffer.length) {
throw new Error(`File size ${downloadedBuffer.length} is not ${fixtureBuffer.length}`)
}
})
})
})
})
Loading

0 comments on commit 810d6f5

Please sign in to comment.