2020-12-30 22:37:41 +00:00
|
|
|
context('Playlists', () => {
|
2021-01-01 13:31:53 +00:00
|
|
|
beforeEach(() => cy.$login())
|
|
|
|
|
2020-12-30 22:37:41 +00:00
|
|
|
it('displays a playlist when sidebar menu item is clicked', () => {
|
|
|
|
cy.intercept('GET', '/api/playlist/1/songs', {
|
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
2021-01-01 13:31:53 +00:00
|
|
|
cy.$clickSidebarItem('Simple Playlist')
|
2020-12-30 22:37:41 +00:00
|
|
|
|
2020-12-31 19:01:09 +00:00
|
|
|
cy.get('#playlistWrapper').within(() => {
|
|
|
|
cy.get('.heading-wrapper')
|
|
|
|
.should('be.visible')
|
|
|
|
.and('contain', 'Simple Playlist')
|
2020-12-30 22:37:41 +00:00
|
|
|
|
2020-12-31 19:01:09 +00:00
|
|
|
cy.get('tr.song-item')
|
2020-12-30 22:37:41 +00:00
|
|
|
.should('be.visible')
|
2020-12-31 19:01:09 +00:00
|
|
|
.and('have.length', 3)
|
|
|
|
|
|
|
|
cy.findByText('Download All').should('be.visible')
|
|
|
|
;['.btn-shuffle-all', '.btn-delete-playlist'].forEach(selector => cy.get(selector).should('be.visible'))
|
2020-12-30 22:37:41 +00:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2020-12-31 21:51:14 +00:00
|
|
|
it('deletes a playlist', () => {
|
2020-12-30 22:37:41 +00:00
|
|
|
cy.intercept('GET', '/api/playlist/1/songs', {
|
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.intercept('DELETE', '/api/playlist/1', {})
|
|
|
|
|
2021-01-01 13:31:53 +00:00
|
|
|
cy.$clickSidebarItem('Simple Playlist').as('menuItem')
|
2020-12-30 22:37:41 +00:00
|
|
|
|
|
|
|
cy.get('#playlistWrapper .btn-delete-playlist')
|
|
|
|
.click()
|
|
|
|
.$confirm()
|
|
|
|
|
2020-12-31 19:01:09 +00:00
|
|
|
cy.url().should('contain', '/#!/home')
|
|
|
|
cy.get('@menuItem').should('not.exist')
|
2020-12-30 22:37:41 +00:00
|
|
|
})
|
|
|
|
|
2020-12-31 21:51:14 +00:00
|
|
|
it('deletes a playlist from the sidebar', () => {
|
|
|
|
cy.intercept('GET', '/api/playlist/2/songs', {
|
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.intercept('DELETE', '/api/playlist/2', {})
|
|
|
|
|
|
|
|
cy.get('#sidebar')
|
|
|
|
.findByText('Smart Playlist')
|
|
|
|
.as('menuItem')
|
|
|
|
.rightclick()
|
|
|
|
|
|
|
|
cy.findByTestId('playlist-context-menu-delete-2').click()
|
|
|
|
cy.$confirm()
|
|
|
|
|
|
|
|
cy.url().should('contain', '/#!/home')
|
|
|
|
cy.get('@menuItem').should('not.exist')
|
|
|
|
})
|
|
|
|
|
2020-12-30 22:37:41 +00:00
|
|
|
it('creates a simple playlist from the sidebar', () => {
|
2020-12-31 21:04:57 +00:00
|
|
|
cy.intercept('GET', '/api/playlist/3/songs', [])
|
2020-12-30 22:37:41 +00:00
|
|
|
|
|
|
|
cy.intercept('POST', '/api/playlist', {
|
|
|
|
fixture: 'playlist.post.200.json'
|
|
|
|
})
|
|
|
|
|
2020-12-31 19:01:09 +00:00
|
|
|
cy.findByTestId('sidebar-create-playlist-btn').click()
|
|
|
|
cy.findByTestId('playlist-context-menu-create-simple').click()
|
2020-12-30 22:37:41 +00:00
|
|
|
|
|
|
|
cy.get('[name=create-simple-playlist-form] [name=name]')
|
|
|
|
.as('nameInput')
|
|
|
|
.should('be.visible')
|
|
|
|
|
|
|
|
cy.get('@nameInput')
|
|
|
|
.clear()
|
|
|
|
.type('A New Playlist{enter}')
|
|
|
|
|
|
|
|
cy.get('#sidebar')
|
|
|
|
.findByText('A New Playlist')
|
|
|
|
.should('exist')
|
|
|
|
.and('have.class', 'active')
|
|
|
|
|
2020-12-31 19:01:09 +00:00
|
|
|
cy.findByText('Created playlist "A New Playlist".').should('be.visible')
|
2020-12-30 22:37:41 +00:00
|
|
|
|
|
|
|
cy.get('#playlistWrapper .heading-wrapper')
|
|
|
|
.should('be.visible')
|
|
|
|
.and('contain', 'A New Playlist')
|
|
|
|
|
|
|
|
cy.get('#playlistWrapper .none')
|
|
|
|
.should('be.visible')
|
|
|
|
.and('contain', 'The playlist is currently empty.')
|
|
|
|
})
|
|
|
|
|
2021-01-01 15:49:41 +00:00
|
|
|
it('creates a playlist directly from a song list', () => {
|
|
|
|
cy.intercept('GET', '/api/playlist/1/songs', {
|
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
2021-01-02 11:58:46 +00:00
|
|
|
cy.intercept('PUT', '/api/playlist/1/sync', {})
|
2021-01-01 15:49:41 +00:00
|
|
|
|
2021-01-02 11:58:46 +00:00
|
|
|
cy.$assertPlaylistSongCount('Simple Playlist', 3)
|
2021-01-01 15:49:41 +00:00
|
|
|
|
|
|
|
cy.$clickSidebarItem('All Songs')
|
|
|
|
|
|
|
|
cy.get('#songsWrapper').within(() => {
|
|
|
|
cy.get('tr.song-item:first-child').click()
|
|
|
|
cy.get('tr.song-item:nth-child(2)').click({ shiftKey: true })
|
|
|
|
cy.get('[data-test=add-to-btn]').click()
|
|
|
|
cy.get('[data-test=add-to-menu]')
|
|
|
|
.should('be.visible')
|
|
|
|
.within(() => cy.findByText('Simple Playlist').click())
|
|
|
|
.should('not.be.visible')
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.findByText('Added 2 songs into "Simple Playlist".').should('be.visible')
|
2021-01-02 11:58:46 +00:00
|
|
|
cy.$assertPlaylistSongCount('Simple Playlist', 5)
|
2021-01-01 15:58:52 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
it('creates a playlist directly from songs', () => {
|
|
|
|
cy.intercept('POST', '/api/playlist', {
|
|
|
|
fixture: 'playlist.post.200.json'
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.intercept('GET', '/api/playlist/3/songs', {
|
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.$clickSidebarItem('All Songs')
|
|
|
|
|
|
|
|
cy.get('#songsWrapper').within(() => {
|
|
|
|
cy.get('tr.song-item:first-child').click()
|
|
|
|
cy.get('tr.song-item:nth-child(3)').click({ shiftKey: true })
|
|
|
|
cy.get('[data-test=add-to-btn]').click()
|
|
|
|
cy.get('[data-test=new-playlist-name]').type('A New Playlist{enter}')
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.get('#sidebar')
|
|
|
|
.findByText('A New Playlist')
|
|
|
|
.should('exist')
|
|
|
|
.and('have.class', 'active')
|
|
|
|
|
|
|
|
cy.findByText('Created playlist "A New Playlist".').should('be.visible')
|
2021-01-02 11:58:46 +00:00
|
|
|
cy.$assertPlaylistSongCount('A New Playlist', 3)
|
2021-01-01 15:49:41 +00:00
|
|
|
})
|
|
|
|
|
2020-12-30 22:37:41 +00:00
|
|
|
it('updates a simple playlist from the sidebar', () => {
|
|
|
|
cy.intercept('PUT', '/api/playlist/1', {})
|
|
|
|
cy.intercept('GET', '/api/playlist/1/songs', {
|
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.get('#sidebar')
|
|
|
|
.findByText('Simple Playlist')
|
|
|
|
.as('menuItem')
|
|
|
|
.dblclick()
|
|
|
|
|
|
|
|
cy.findByTestId('inline-playlist-name-input')
|
|
|
|
.as('nameInput')
|
|
|
|
.should('be.focused')
|
|
|
|
|
|
|
|
cy.get('@nameInput')
|
|
|
|
.clear()
|
|
|
|
.type('A New Name{enter}')
|
|
|
|
|
|
|
|
cy.get('@menuItem')
|
|
|
|
.should('contain', 'A New Name')
|
|
|
|
.and('have.class', 'active')
|
|
|
|
|
2020-12-31 19:01:09 +00:00
|
|
|
cy.findByText('Updated playlist "A New Name".').should('be.visible')
|
2020-12-30 22:37:41 +00:00
|
|
|
|
|
|
|
cy.get('#playlistWrapper .heading-wrapper')
|
|
|
|
.should('be.visible')
|
|
|
|
.and('contain', 'A New Name')
|
|
|
|
})
|
2020-12-31 19:01:09 +00:00
|
|
|
|
|
|
|
it('creates a smart playlist', () => {
|
|
|
|
cy.intercept('POST', '/api/playlist', {
|
|
|
|
fixture: 'playlist-smart.post.200.json'
|
|
|
|
})
|
|
|
|
|
2020-12-31 21:04:57 +00:00
|
|
|
cy.intercept('GET', '/api/playlist/3/songs', {
|
2020-12-31 19:01:09 +00:00
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.findByTestId('sidebar-create-playlist-btn').click()
|
|
|
|
cy.findByTestId('playlist-context-menu-create-smart').click()
|
|
|
|
|
|
|
|
cy.findByTestId('create-smart-playlist-form')
|
|
|
|
.should('be.visible')
|
|
|
|
.within(() => {
|
|
|
|
cy.get('[name=name]')
|
|
|
|
.should('be.focused')
|
|
|
|
.type('My Smart Playlist')
|
|
|
|
|
|
|
|
cy.get('.btn-add-group').click()
|
|
|
|
|
|
|
|
// Add the first rule
|
|
|
|
cy.get('.btn-add-rule').click()
|
|
|
|
cy.get('[name="model[]"]').select('Album')
|
|
|
|
cy.get('[name="operator[]"]').select('is not')
|
|
|
|
cy.wait(0) // the "value" text box is rendered asynchronously
|
|
|
|
cy.get('[name="value[]"]').type('Foo')
|
|
|
|
|
|
|
|
// Add a second rule
|
|
|
|
cy.get('.btn-add-rule').click()
|
|
|
|
cy.get('[data-test=smart-playlist-rule-row]:nth-child(3) [name="model[]"]').select('Length')
|
|
|
|
cy.get('[data-test=smart-playlist-rule-row]:nth-child(3) [name="operator[]"]').select('is greater than')
|
|
|
|
cy.wait(0)
|
|
|
|
cy.get('[data-test=smart-playlist-rule-row]:nth-child(3) [name="value[]"]').type('180')
|
|
|
|
|
|
|
|
// Add another group (and rule)
|
|
|
|
cy.get('.btn-add-group').click()
|
|
|
|
cy.get('[data-test=smart-playlist-rule-group]:nth-child(2) .btn-add-rule').click()
|
|
|
|
cy.wait(0)
|
|
|
|
cy.get('[data-test=smart-playlist-rule-group]:nth-child(2) [name="value[]"]').type('Whatever')
|
|
|
|
|
|
|
|
// Remove a rule from the first group
|
|
|
|
cy.get(`
|
|
|
|
[data-test=smart-playlist-rule-group]:first-child
|
|
|
|
[data-test=smart-playlist-rule-row]:nth-child(2)
|
|
|
|
.remove-rule
|
|
|
|
`).click()
|
|
|
|
|
|
|
|
cy.get('[data-test=smart-playlist-rule-group]:first-child [data-test=smart-playlist-rule-row]')
|
|
|
|
.should('have.length', 1)
|
|
|
|
|
|
|
|
cy.findByText('Save').click()
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.findByText('Created playlist "My Smart Playlist".').should('be.visible')
|
|
|
|
|
2021-01-01 15:58:52 +00:00
|
|
|
cy.get('#playlistWrapper .heading-wrapper')
|
2020-12-31 19:01:09 +00:00
|
|
|
.should('be.visible')
|
|
|
|
.and('contain', 'My Smart Playlist')
|
|
|
|
|
|
|
|
cy.get('#sidebar')
|
|
|
|
.findByText('My Smart Playlist')
|
|
|
|
.should('have.class', 'active')
|
2021-01-01 15:58:52 +00:00
|
|
|
|
2021-01-02 11:58:46 +00:00
|
|
|
cy.$assertPlaylistSongCount('My Smart Playlist', 3)
|
2020-12-31 19:01:09 +00:00
|
|
|
})
|
2020-12-31 21:52:09 +00:00
|
|
|
|
|
|
|
it('updates a smart playlist', () => {
|
|
|
|
cy.intercept('GET', '/api/playlist/2/songs', {
|
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.intercept('GET', '/api/playlist/2/songs', {
|
|
|
|
fixture: 'playlist-songs.get.200.json'
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.intercept('PUT', '/api/playlist/2', {})
|
|
|
|
|
|
|
|
cy.get('#sidebar')
|
|
|
|
.findByText('Smart Playlist')
|
|
|
|
.rightclick()
|
|
|
|
|
|
|
|
cy.findByTestId('playlist-context-menu-edit-2').click()
|
|
|
|
|
|
|
|
cy.findByTestId('edit-smart-playlist-form')
|
|
|
|
.should('be.visible')
|
|
|
|
.within(() => {
|
|
|
|
cy.get('[name=name]')
|
|
|
|
.should('be.focused')
|
|
|
|
.and('contain.value', 'Smart Playlist')
|
|
|
|
.clear()
|
|
|
|
.type('A Different Name')
|
|
|
|
|
|
|
|
cy.get('[data-test=smart-playlist-rule-group]').should('have.length', 2)
|
|
|
|
|
|
|
|
// Add another rule into the second group
|
|
|
|
cy.get('[data-test=smart-playlist-rule-group]:nth-child(2) .btn-add-rule').click()
|
|
|
|
cy.get('[data-test=smart-playlist-rule-row]:nth-child(3) [name="model[]"]').select('Album')
|
|
|
|
cy.get('[data-test=smart-playlist-rule-row]:nth-child(3) [name="operator[]"]').select('contains')
|
|
|
|
cy.wait(0)
|
|
|
|
cy.get('[data-test=smart-playlist-rule-row]:nth-child(3) [name="value[]"]').type('keyword')
|
|
|
|
cy.get('[data-test=smart-playlist-rule-group]:nth-child(2) [data-test=smart-playlist-rule-row]')
|
|
|
|
.should('have.length', 2)
|
|
|
|
|
|
|
|
cy.findByText('Save').click()
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.findByText('Updated playlist "A Different Name".').should('be.visible')
|
|
|
|
|
|
|
|
cy.get('#playlistWrapper .heading-wrapper')
|
|
|
|
.should('be.visible')
|
|
|
|
.and('contain', 'A Different Name')
|
|
|
|
})
|
2020-12-30 22:37:41 +00:00
|
|
|
})
|