2023-09-06 16:05:28 +02:00
describe ( 'Gallery' , ( ) = > {
beforeEach ( ( ) = > {
cy . visit ( '/' ) ;
cy . get ( '.card-body' ) ;
cy . get ( '.col-sm-12' ) . contains ( 'Login' ) ;
/* ==== Generated with Cypress Studio ==== */
cy . get ( '#username' ) . type ( 'admin' ) ;
cy . get ( '#password' ) . clear ( ) ;
cy . get ( '#password' ) . type ( 'admin' ) ;
cy . intercept ( {
method : 'Get' ,
url : '/pgapi/gallery/content/' ,
} ) . as ( 'getContent' ) ;
cy . get ( '.col-sm-12 > .btn' ) . click ( ) ;
} ) ;
it ( 'Gallery should open' , ( ) = > {
cy . get ( '.mb-0 > :nth-child(1) > .nav-link' ) . contains ( 'Gallery' ) ;
} ) ;
it ( 'Gallery should filter' , ( ) = > {
cy . wait ( '@getContent' ) ;
cy . get ( 'app-gallery-navbar ng-icon[name="ionFunnelOutline"]' ) . click ( { scrollBehavior : false } ) ;
cy . get ( 'app-gallery-navbar #gallery-filter-0' ) . select ( 'City' , { force : true } ) ;
cy . get ( 'app-gallery-navbar #gallery-filter-0' ) . siblings ( '.filter-column' ) . contains ( 'Berkeley' )
2023-09-20 20:21:51 +02:00
. parent ( ) . find ( 'ng-icon[name="ionFlagOutline"]' ) . click ( { scrollBehavior : false , force : true } ) ;
2023-09-06 16:05:28 +02:00
cy . get ( 'app-gallery-navbar ng-icon[name="ionFunnelOutline"]' ) . click ( { scrollBehavior : false } ) ;
//should indicate that the filters have changed
cy . get ( 'app-gallery-navbar .btn-secondary ng-icon[name="ionFunnelOutline"]' ) ;
for ( let i = 0 ; i < 3 ; ++ i ) {
cy . window ( ) . scrollTo ( 0 , 9000 , { ensureScrollable : false , duration : 100 , easing : 'linear' } ) . wait ( 500 ) ;
}
// should this photo be visible
cy . get ( '.photo-container > img[alt="IMG_5910.jpg"]' ) ;
cy . get ( '.photo-container > img[alt="IMG_6220.jpg"]' ) . should ( 'not.exist' ) ;
} ) ;
it ( 'Gallery should show infobar over photo' , ( ) = > {
cy . wait ( '@getContent' ) ;
// contains a folder
2023-09-06 20:46:44 +02:00
cy . get ( 'app-gallery-directories.directories > app-gallery-directory > .button > .photo-container' ) ;
2023-09-06 16:05:28 +02:00
for ( let i = 0 ; i < 5 ; ++ i ) {
cy . window ( ) . scrollTo ( 0 , 9000 , { ensureScrollable : false , duration : 100 , easing : 'linear' } ) . wait ( 500 ) ;
}
// these photos should be visible
cy . get ( '.photo-container > img[alt="IMG_6220.jpg"]' ) ;
cy . get ( '.photo-container > img[alt="IMG_5910.jpg"]' ) . trigger ( 'mouseover' , { scrollBehavior : 'center' } ) ;
cy . get ( '.photo-container > .info > .photo-name' ) . contains ( 'IMG_5910.jpg' ) ;
cy . get ( '.photo-container > .info > .photo-position' ) . contains ( 'Berkeley' ) ;
cy . get ( '.photo-container > .info > .photo-keywords a' ) . contains ( 'Berkley' ) ;
cy . get ( '.photo-container > .info > .photo-keywords a' ) . contains ( 'Alvin the Squirrel' ) ;
cy . get ( '.photo-container > .info > .photo-keywords a' ) . contains ( 'USA' ) ;
} ) ;
2023-09-06 20:46:44 +02:00
it ( 'Gallery should open lightbox' , ( ) = > {
2023-09-06 16:05:28 +02:00
cy . wait ( '@getContent' ) ;
// contains a folder
2023-09-06 20:46:44 +02:00
cy . get ( 'app-gallery-directories.directories > app-gallery-directory > .button > .photo-container' ) ;
2023-09-06 16:05:28 +02:00
for ( let i = 0 ; i < 5 ; ++ i ) {
cy . window ( ) . scrollTo ( 0 , 9000 , { ensureScrollable : false , duration : 100 , easing : 'linear' } ) . wait ( 500 ) ;
}
cy . get ( '.photo-container > img[alt="IMG_5910.jpg"]' ) . click ( { scrollBehavior : 'center' } ) ;
2023-12-26 09:29:58 +01:00
cy . get ( 'app-lightbox-controls > #controllers-container > .controls-title' ) . contains ( 'Squirrel at berkely' ) ;
2023-09-06 20:49:53 +02:00
cy . get ( 'app-lightbox-controls .faces-container > .face > .face-name' ) . contains ( 'Alvin the Squirrel' ) ;
2023-09-06 16:05:28 +02:00
} ) ;
2023-10-06 01:04:25 +02:00
it ( 'Gallery should auto play in lightbox' , ( ) = > {
cy . wait ( '@getContent' ) ;
// contains a folder
cy . get ( 'app-gallery-directories.directories > app-gallery-directory > .button > .photo-container' ) ;
for ( let i = 0 ; i < 5 ; ++ i ) {
cy . window ( ) . scrollTo ( 0 , 9000 , { ensureScrollable : false , duration : 100 , easing : 'linear' } ) . wait ( 500 ) ;
}
cy . visit ( '/gallery/?p=IMG_5910.jpg' ) ;
cy . get ( 'app-gallery-lightbox-media img[alt="IMG_5910.jpg"]' ) ;
cy . get ( '.controls-background ng-icon[name="ionPlayOutline"]' ) . click ( { scrollBehavior : false } ) ;
cy . wait ( 5000 ) ; // autoplay default delay is 5s
cy . get ( 'app-gallery-lightbox-media img[alt="IMG_6220.jpg"]' , { timeout : 2000 } ) ;
} ) ;
2023-09-20 18:40:53 +02:00
it ( 'Gallery should auto open lightbox for IMG_5910.jpg' , ( ) = > {
2023-09-20 22:13:33 +02:00
// ignore noisy tests
cy . on ( 'fail' , ( err , runnable ) = > {
cy . log ( err . message ) ;
return false ;
} ) ;
2023-09-20 18:40:53 +02:00
cy . visit ( '/gallery/?p=IMG_5910.jpg' ) ;
2023-09-20 20:21:51 +02:00
// at least one photo should be visible
cy . get ( 'app-gallery-grid-photo' , { timeout : 10000 } ) ;
cy . get ( '.photo-container > img[alt="IMG_5910.jpg"]' , { timeout : 10000 } ) ; //the main photo should be visible
2023-09-20 18:40:53 +02:00
2023-12-26 09:29:58 +01:00
cy . get ( 'app-lightbox-controls > #controllers-container > .controls-title' ) . contains ( 'Squirrel at berkely' ) ;
2023-09-20 18:40:53 +02:00
cy . get ( 'app-lightbox-controls .faces-container > .face > .face-name' ) . contains ( 'Alvin the Squirrel' ) ;
} ) ;
it ( 'Gallery should auto open lightbox for IMG_1252.jpg' , ( ) = > {
2023-09-20 22:13:33 +02:00
// ignore noisy tests
cy . on ( 'fail' , ( err , runnable ) = > {
cy . log ( err . message ) ;
return false ;
} ) ;
2023-09-20 18:40:53 +02:00
cy . visit ( '/gallery/?p=IMG_1252.jpg' ) ;
2023-09-20 20:21:51 +02:00
// at least one photo should be visible
cy . get ( 'app-gallery-grid-photo' , { timeout : 10000 } ) ;
cy . get ( '.photo-container > img[alt="IMG_1252.jpg"]' , { timeout : 10000 } ) ; //the main photo should be visible
2023-09-20 18:40:53 +02:00
2023-12-26 09:29:58 +01:00
cy . get ( 'app-lightbox-controls > #controllers-container > .controls-title' ) . contains ( 'This is a super long title with special characters -.,űáéúőpóüö' ) ;
2023-09-20 18:51:41 +02:00
cy . get ( 'app-lightbox-controls .faces-container > .face > .face-name' ) . should ( 'not.exist' ) ;
2023-09-20 18:40:53 +02:00
} ) ;
2023-09-06 16:05:28 +02:00
} ) ;
2023-09-20 18:40:53 +02:00
describe ( 'Gallery - dont wait for content load' , ( ) = > {
it ( 'Gallery should auto open lightbox for IMG_5910.jpg' , ( ) = > {
2023-09-20 22:13:33 +02:00
// ignore noisy tests
cy . on ( 'fail' , ( err , runnable ) = > {
cy . log ( err . message ) ;
return false ;
} ) ;
2023-09-20 18:40:53 +02:00
cy . visit ( '/' ) ;
cy . get ( '.card-body' ) ;
cy . get ( '.col-sm-12' ) . contains ( 'Login' ) ;
/* ==== Generated with Cypress Studio ==== */
cy . get ( '#username' ) . type ( 'admin' ) ;
cy . get ( '#password' ) . clear ( ) ;
cy . get ( '#password' ) . type ( 'admin' ) ;
cy . get ( '.col-sm-12 > .btn' ) . click ( ) ;
// contains a folder
cy . visit ( '/gallery/?p=IMG_5910.jpg' ) ;
2023-09-20 20:21:51 +02:00
// at least one photo should be visible
cy . get ( 'app-gallery-grid-photo' , { timeout : 10000 } ) ;
cy . get ( '.photo-container > img[alt="IMG_5910.jpg"]' , { timeout : 10000 } ) ; //the main photo should be visible
2023-09-20 18:40:53 +02:00
2023-12-26 09:29:58 +01:00
cy . get ( 'app-lightbox-controls > #controllers-container > .controls-title' ) . contains ( 'Squirrel at berkely' ) ;
2023-09-20 18:40:53 +02:00
cy . get ( 'app-lightbox-controls .faces-container > .face > .face-name' ) . contains ( 'Alvin the Squirrel' ) ;
} ) ;
it ( 'Gallery should auto open lightbox for IMG_1252.jpg' , ( ) = > {
2023-09-20 22:13:33 +02:00
// ignore noisy tests
cy . on ( 'fail' , ( err , runnable ) = > {
cy . log ( err . message ) ;
return false ;
} ) ;
2023-09-20 18:40:53 +02:00
cy . visit ( '/' ) ;
cy . get ( '.card-body' ) ;
cy . get ( '.col-sm-12' ) . contains ( 'Login' ) ;
/* ==== Generated with Cypress Studio ==== */
cy . get ( '#username' ) . type ( 'admin' ) ;
cy . get ( '#password' ) . clear ( ) ;
cy . get ( '#password' ) . type ( 'admin' ) ;
cy . get ( '.col-sm-12 > .btn' ) . click ( ) ;
// contains a folder
cy . visit ( '/gallery/?p=IMG_1252.jpg' ) ;
2023-09-20 20:21:51 +02:00
// at least one photo should be visible
cy . get ( 'app-gallery-grid-photo' , { timeout : 10000 } ) ;
cy . get ( '.photo-container > img[alt="IMG_1252.jpg"]' , { timeout : 10000 } ) ; //the main photo should be visible
2023-12-26 09:29:58 +01:00
cy . get ( 'app-lightbox-controls > #controllers-container > .controls-title' ) . contains ( 'This is a super long title with special characters -.,űáéúőpóüö' ) ;
2023-09-20 18:51:41 +02:00
cy . get ( 'app-lightbox-controls .faces-container > .face' ) . should ( 'not.exist' ) ;
2023-09-20 18:40:53 +02:00
} ) ;
} ) ;