Skip to content

Commit

Permalink
Merge branch 'main' into task/WI-212
Browse files Browse the repository at this point in the history
  • Loading branch information
fnets authored Dec 19, 2024
2 parents 0a6852b + 5b3872f commit 84750e5
Show file tree
Hide file tree
Showing 27 changed files with 807 additions and 214 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -324,3 +324,102 @@ describe('DataFilesListing - Section Name Determination', () => {
).toBeInTheDocument();
});
});
describe('DataFilesListing - showViewPath', () => {
afterEach(() => {
vi.restoreAllMocks();
});
it('renders the "Path" column when showViewPath is true', () => {
const testfile = {
system: 'test.system',
path: '/path/to/file',
name: 'testfile',
format: 'file',
length: 4096,
lastModified: '2019-06-17T15:49:53-05:00',
_links: { self: { href: 'href.test' } },
};
const history = createMemoryHistory();
history.push('/workbench/data/tapis/private/test.system/');
const store = mockStore({
...initialMockState,
files: {
...initialMockState.files,
listing: { FilesListing: [testfile] },
},
workbench: {
config: {
viewPath: true,
},
},
});
// Spy on useMemo to capture the cells array
const useMemoSpy = vi
.spyOn(React, 'useMemo')
.mockImplementation((fn) => fn());
const { getByText } = renderComponent(
<DataFilesListing
api="tapis"
scheme="private"
system="test.system"
resultCount={4}
path="/"
/>,
store,
history
);
// Path cell is added
expect(getByText('Path')).toBeDefined();
// Check the length of the cells array
const cellsArray = useMemoSpy.mock.results.find((result) =>
Array.isArray(result.value)
).value;
expect(cellsArray.length).toBe(6);
});
it('does not render the "Path" column when showViewPath is false', () => {
const testfile = {
system: 'test.system',
path: '/path/to/file',
name: 'testfile',
format: 'file',
length: 4096,
lastModified: '2019-06-17T15:49:53-05:00',
_links: { self: { href: 'href.test' } },
};
const history = createMemoryHistory();
history.push('/workbench/data/tapis/private/test.system/');
const store = mockStore({
...initialMockState,
files: {
...initialMockState.files,
listing: { FilesListing: [testfile] },
},
workbench: {
config: {
viewPath: false,
},
},
});
// Spy on useMemo to capture the cells array
const useMemoSpy = vi
.spyOn(React, 'useMemo')
.mockImplementation((fn) => fn());
const { queryByText } = renderComponent(
<DataFilesListing
api="tapis"
scheme="private"
system="test.system"
resultCount={4}
path="/"
/>,
store,
history
);
// Path should not exist as a new cell
expect(queryByText('Path')).toBeNull();
// Check the length of the cells array
const cellsArray = useMemoSpy.mock.results.find((result) =>
Array.isArray(result.value)
).value;
expect(cellsArray.length).toBe(5);
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -101,11 +101,10 @@ const DataFilesPreviewModal = () => {
<NiiVue imageUrl={href} fileName={params.path}></NiiVue>
)}
{previewUsingHref && !previewUsingBrainmap && (
<div className="embed-responsive embed-responsive-4by3">
<div className="ratio ratio-4x3">
<iframe
title="preview"
frameBorder="0"
className="embed-responsive-item"
onLoad={onFrameLoad}
src={href}
/>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,19 +5,25 @@ import { LoadingSpinner, InlineMessage, Button } from '_common';
import { FileLengthCell } from '../../DataFilesListing/DataFilesListingCells';
import { useUpload } from 'hooks/datafiles/mutations';
import styles from './DataFilesUploadModalListingTable.module.scss';
import { useSelector } from 'react-redux';

const DataFilesUploadStatus = ({ i, removeCallback, rejectedFiles }) => {
if (rejectedFiles.filter((f) => f.id === i).length > 0) {
return <InlineMessage type="error">Exceeds File Size Limit</InlineMessage>;
}
const errorMessage = useSelector((state) => state.files.error.message);
const status = useUpload().status[i];
switch (status) {
case 'UPLOADING':
return <LoadingSpinner placement="inline" />;
case 'SUCCESS':
return <span className="badge badge-success">SUCCESS</span>;
case 'ERROR':
return <InlineMessage type="error">Upload Failed</InlineMessage>;
return (
<InlineMessage type="error">
Upload Failed: {errorMessage}
</InlineMessage>
);
default:
return (
<Button type="link" onClick={() => removeCallback(i)}>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,20 +55,7 @@ describe('DataFilesCopyModal', () => {
const submitButton = getByText('Create Folder');
fireEvent.click(submitButton);
});

expect(store.getActions()).toEqual([
{
type: 'DATA_FILES_MKDIR',
payload: {
api: 'tapis',
scheme: 'private',
system: 'test.system',
path: '/',
dirname: 'abc123',
reloadCallback: expect.any(Function),
},
},
]);
// TODO: New test needed for react redux call for mkdir
});

it('Error message on invalid input', async () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ describe('DataFilesSidebar', () => {
).toEqual(
'/workbench/data/tapis/private/longhorn.home.username/home/username/'
);
expect(queryByText(/My Data \(Work\)/)).toBeNull();
expect(queryByText(/My Data \(Work\)/)).toBeDefined();
});

it('disables creating new shared workspaces in read only shared workspaces', async () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ describe('DataFilesSystemSelector', () => {
store,
history
);
expect(queryByText(/My Data \(Work\)/)).toBeNull();
expect(queryByText(/My Data \(Work\)/)).toBeDefined();
expect(queryByText(/My Data \(Frontera\)/)).toBeDefined();
expect(queryByText(/My Data \(Longhorn\)/)).toBeDefined();
expect(queryByText(/Google Drive/)).toBeDefined();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import getFilePermissions from 'utils/filePermissions';
import { useModal, useSelectedFiles, useFileListing } from 'hooks/datafiles';
import { useSystemRole } from '../DataFilesProjectMembers/_cells/SystemRoleSelector';
import './DataFilesToolbar.scss';
import { useTrash } from 'hooks/datafiles/mutations';

export const ToolbarButton = ({ text, iconName, onClick, disabled }) => {
const iconClassName = `action icon-${iconName}`;
Expand Down Expand Up @@ -40,6 +41,7 @@ const DataFilesToolbar = ({ scheme, api }) => {
const { toggle } = useModal();
const { selectedFiles } = useSelectedFiles();
const { params } = useFileListing('FilesListing');
const { trash } = useTrash();

const history = useHistory();
const location = useLocation();
Expand Down Expand Up @@ -172,20 +174,15 @@ const DataFilesToolbar = ({ scheme, api }) => {
}
};

const trash = useCallback(() => {
const filteredSelected = selectedFiles.filter(
(f) => status[f.system + f.path] !== 'SUCCESS'
);
const homeDir = selectedSystem?.homeDir;

dispatch({
type: 'DATA_FILES_TRASH',
payload: {
src: filteredSelected,
homeDir: selectedSystem?.homeDir || '',
reloadCallback: reloadPage,
},
const trashCallback = useCallback(() => {
trash({
destSystem: selectedSystem.system,
homeDir: homeDir,
callback: reloadPage,
});
}, [selectedFiles, selectedSystem, reloadPage]);
}, [selectedFiles, reloadPage, status]);

const empty = () => {
dispatch({
Expand Down Expand Up @@ -271,7 +268,7 @@ const DataFilesToolbar = ({ scheme, api }) => {
<ToolbarButton
text={!inTrash ? 'Trash' : 'Empty'}
iconName="trash"
onClick={!inTrash ? trash : empty}
onClick={!inTrash ? trashCallback : empty}
disabled={!inTrash ? !canTrash : !canEmpty}
className={!inTrash ? '' : 'is-empty'}
/>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
/* TODOv3 update this fixture https://jira.tacc.utexas.edu/browse/WP-68*/

// Updated fixture changes from endpoint https://cep.test/api/datafiles/systems/list/
// Removed from configuration: hidden, keyservice
// Removed from storage and defintions array: errorMessage, loading
const systemsFixture = {
storage: {
configuration: [
Expand All @@ -9,10 +11,8 @@ const systemsFixture = {
scheme: 'private',
api: 'tapis',
icon: null,
hidden: true,
homeDir: '/home/username',
default: true,
keyservice: true,
},
{
name: 'My Data (Frontera)',
Expand Down Expand Up @@ -65,13 +65,30 @@ const systemsFixture = {
integration: 'portal.apps.googledrive_integration',
},
],
error: false,
errorMessage: null,
loading: false,
/*
* The following needs to be mirrored for the storage and definitions
These are included in the datafiles reducers but pass tests without these
This means that tests need to be more comprehensive to catch this or removed
Definitions that use variables other than list are used in:
- DataFilesTable.jsx:45 for error
state.systems.definitions.* is not called for anything else other than error
These would need to be removed then
- errorMessage
- loading
*/

//error: false,
//errorMessage: null,
//loading: false,
defaultHost: 'frontera.tacc.utexas.edu',
defaultSystem: 'frontera',
},
// This definitions is required for the tests, some can be removed. Referencing datafiles.reducers.js
definitions: {
// For DataFilesTable and DataFilesShowPathModal it requires the id from this list
list: [
{
id: 'frontera.home.username',
Expand All @@ -90,9 +107,9 @@ const systemsFixture = {
effectiveUserId: 'username',
},
],
error: false,
errorMessage: null,
loading: false,
error: false, // Commenting this out results in an error
//errorMessage: null,
//loading: false,
},
};

Expand Down
3 changes: 2 additions & 1 deletion client/src/components/DataFiles/tests/DataFiles.test.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ describe('DataFiles', () => {
//);
expect(getAllByText(/My Data \(Frontera\)/)).toBeDefined();
expect(getByText(/My Data \(Longhorn\)/)).toBeDefined();
expect(queryByText(/My Data \(Work\)/)).toBeNull();
expect(queryByText(/My Data \(Work\)/)).toBeDefined(); // Changed to defined, hidden attribute removed and would be defined by default
});

it('should not render Data Files with no systems', () => {
Expand All @@ -62,6 +62,7 @@ describe('DataFiles', () => {
},
},
systems: {
// TODO: Remove rest of unused variables
storage: {
configuration: [
{
Expand Down
1 change: 1 addition & 0 deletions client/src/components/PublicData/PublicData.module.css
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,4 @@
/* FAQ: Public pages, like `PublicData` and `SiteSearch`, have no sidebar */
/* padding-left: 1.5em; /* ~24px (20px * design * 1.2 design-to-app ratio) */
}

2 changes: 1 addition & 1 deletion client/src/components/Submissions/Submissions.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ const Submissions = () => {

const useSubmitterRole = () => {
const query = useQuery({
queryKey: 'submitter-role',
queryKey: ['submitter-role'],
queryFn: getSubmitterRole,
});
return query;
Expand Down
34 changes: 0 additions & 34 deletions client/src/hooks/datafiles/mutations/useMkdir.js

This file was deleted.

Loading

0 comments on commit 84750e5

Please sign in to comment.