16115: Improves link rendering. Adds tests.
authorLucas Di Pentima <lucas.dipentima@curii.com>
Mon, 16 May 2022 18:58:28 +0000 (15:58 -0300)
committerLucas Di Pentima <lucas.dipentima@curii.com>
Mon, 16 May 2022 18:58:28 +0000 (15:58 -0300)
Arvados-DCO-1.1-Signed-off-by: Lucas Di Pentima <lucas.dipentima@curii.com>

cypress/integration/sharing.spec.js
src/views-components/sharing-dialog/sharing-urls-component.test.tsx
src/views-components/sharing-dialog/sharing-urls-component.tsx
tools/arvados_config.yml

index df7c74363bc1c4c188a210784e022819ebe81280..1d3112c2c8187fd6e0b04309de56e51b8a9fea87 100644 (file)
@@ -14,13 +14,11 @@ describe('Sharing tests', function () {
         cy.getUser('admin', 'Admin', 'User', true, true)
             .as('adminUser').then(function () {
                 adminUser = this.adminUser;
-            }
-            );
+            });
         cy.getUser('collectionuser1', 'Collection', 'User', false, true)
             .as('activeUser').then(function () {
                 activeUser = this.activeUser;
-            }
-            );
+            });
     })
 
     beforeEach(function () {
@@ -28,6 +26,38 @@ describe('Sharing tests', function () {
         cy.clearLocalStorage()
     });
 
+    it('can create and delete sharing URLs on collections', () => {
+        const collName = 'shared-collection ' + new Date().getTime();
+        cy.createCollection(adminUser.token, {
+            name: collName,
+            owner_uuid: adminUser.uuid,
+        }).as('sharedCollection').then(function (sharedCollection) {
+            cy.loginAs(adminUser);
+
+            cy.get('main').contains(sharedCollection.name).rightclick();
+            cy.get('[data-cy=context-menu]').within(() => {
+                cy.contains('Share').click();
+            });
+            cy.get('.sharing-dialog').within(() => {
+                cy.contains('Sharing URLs').click();
+                cy.contains('Create sharing URL');
+                cy.contains('No sharing URLs');
+                cy.should('not.contain', 'Token');
+                cy.should('not.contain', 'expiring at:');
+
+                cy.contains('Create sharing URL').click();
+                cy.should('not.contain', 'No sharing URLs');
+                cy.contains('Token');
+                cy.contains('expiring at:');
+
+                cy.get('[data-cy=remove-url-btn]').find('button').click();
+                cy.contains('No sharing URLs');
+                cy.should('not.contain', 'Token');
+                cy.should('not.contain', 'expiring at:');
+            })
+        })
+    });
+
     it('can share projects to other users', () => {
         cy.loginAs(adminUser);
 
@@ -46,8 +76,10 @@ describe('Sharing tests', function () {
             cy.get('.sharing-dialog').as('sharingDialog');
             cy.get('[data-cy=invite-people-field]').find('input').type(activeUser.user.email);
             cy.get('[role=tooltip]').click();
-            cy.get('@sharingDialog').contains('Save changes').click();
-            cy.get('@sharingDialog').contains('Close').click();
+            cy.get('@sharingDialog').within(() => {
+                cy.contains('Save changes').click();
+                cy.contains('Close').click();
+            });
         });
 
         cy.createGroup(adminUser.token, {
@@ -62,8 +94,10 @@ describe('Sharing tests', function () {
             cy.get('.sharing-dialog').as('sharingDialog');
             cy.get('[data-cy=invite-people-field]').find('input').type(activeUser.user.email);
             cy.get('[role=tooltip]').click();
-            cy.get('@sharingDialog').contains('Save changes').click();
-            cy.get('@sharingDialog').contains('Close').click();
+            cy.get('@sharingDialog').within(() => {
+                cy.contains('Save changes').click();
+                cy.contains('Close').click();
+            });
         });
 
         cy.getAll('@mySharedWritableProject', '@mySharedReadonlyProject')
index 0cbc661dfd0de54ebe6bf0fa20bca38bd9143513..cf3884c71969a98f8af9a2b608e05df07f411cd0 100644 (file)
@@ -57,6 +57,14 @@ describe("<SharingURLsComponent />", () => {
         expect(wrapper.find('a').at(1).props().href).toBe(`${props.collectionUuid}${sharingPrefix}/t=${props.sharingTokens[1].apiToken}/_/`);
     });
 
+    it("renders a list of URLs with no expiration", () => {
+        props.sharingTokens[0].expiresAt = null;
+        props.sharingTokens[1].expiresAt = null;
+        wrapper = mount(<SharingURLsComponent {...props} />);
+        expect(wrapper.find('a').at(0).text()).toContain(`Token aaaaaaaa... with no expiration date`);
+        expect(wrapper.find('a').at(1).text()).toContain(`Token bbbbbbbb... with no expiration date`);
+    });
+
     it("calls delete token handler when delete button is clicked", () => {
         wrapper.find('button').at(0).simulate('click');
         expect(props.onDeleteSharingToken).toHaveBeenCalledWith(props.sharingTokens[0].uuid);
index 1638aaf768e33ea7b41900e3084e74669ae44407..c9cbc0df3d5e2f20ad0818a6ee8281e91fb868f8 100644 (file)
@@ -66,7 +66,9 @@ export const SharingURLsComponent = withStyles(styles)((props: SharingURLsCompon
         ? `${props.sharingURLsPrefix.replace('*', props.collectionUuid)}/t=${token.apiToken}/_/`
         : `${props.sharingURLsPrefix}/c=${props.collectionUuid}/t=${token.apiToken}/_/`;
         const expDate = new Date(token.expiresAt);
-        const urlLabel = `Token ${token.apiToken.slice(0, 8)}... expiring at: ${expDate.toLocaleString()} (${moment(expDate).fromNow()})`;
+        const urlLabel = !!token.expiresAt
+        ? `Token ${token.apiToken.slice(0, 8)}... expiring at: ${expDate.toLocaleString()} (${moment(expDate).fromNow()})`
+        : `Token ${token.apiToken.slice(0, 8)}... with no expiration date`;
 
         return <Grid container alignItems='center' key={token.uuid}  className={props.classes.sharingUrlRow}>
             <Grid item>
@@ -81,7 +83,7 @@ export const SharingURLsComponent = withStyles(styles)((props: SharingURLsCompon
                     <CopyIcon />
                 </CopyToClipboard>
             </Tooltip></span>
-            <span className={props.classes.sharingUrlButton}><Tooltip title='Remove'>
+            <span data-cy='remove-url-btn' className={props.classes.sharingUrlButton}><Tooltip title='Remove'>
                 <IconButton onClick={() => props.onDeleteSharingToken(token.uuid)}>
                     <RemoveIcon />
                 </IconButton>
index b9bcfbe0d3327880f39244d321718f374b4f1aac..3b2ecd8d8fe8f93aabbddd3392917c5f6906d9b3 100644 (file)
@@ -5,6 +5,7 @@ Clusters:
     API:
       RequestTimeout: 30s
       VocabularyPath: ""
+      MaxTokenLifetime: 24h
     TLS:
       Insecure: true
     Collections: