Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
117ee702
Commit
117ee702
authored
Mar 01, 2022
by
Darby Frey
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Adding file list component test
parent
2010641f
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
156 additions
and
0 deletions
+156
-0
spec/frontend/ci_secure_files/components/secure_files_list_spec.js
...tend/ci_secure_files/components/secure_files_list_spec.js
+138
-0
spec/frontend/ci_secure_files/mock_data.js
spec/frontend/ci_secure_files/mock_data.js
+18
-0
No files found.
spec/frontend/ci_secure_files/components/secure_files_list_spec.js
0 → 100644
View file @
117ee702
import
{
GlLoadingIcon
}
from
'
@gitlab/ui
'
;
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
{
mount
}
from
'
@vue/test-utils
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
SecureFilesList
from
'
~/ci_secure_files/components/secure_files_list.vue
'
;
import
TimeAgoTooltip
from
'
~/vue_shared/components/time_ago_tooltip.vue
'
;
import
{
secureFiles
}
from
'
../mock_data
'
;
const
dummyApiVersion
=
'
v3000
'
;
const
dummyProjectId
=
1
;
const
dummyUrlRoot
=
'
/gitlab
'
;
const
dummyGon
=
{
api_version
:
dummyApiVersion
,
relative_url_root
:
dummyUrlRoot
,
};
let
originalGon
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/projects/
${
dummyProjectId
}
/secure_files`
;
describe
(
'
SecureFilesList
'
,
()
=>
{
let
wrapper
;
let
mock
;
beforeEach
(()
=>
{
originalGon
=
window
.
gon
;
window
.
gon
=
{
...
dummyGon
};
});
afterEach
(()
=>
{
wrapper
.
destroy
();
mock
.
restore
();
window
.
gon
=
originalGon
;
});
const
createWrapper
=
(
props
=
{})
=>
{
wrapper
=
mount
(
SecureFilesList
,
{
provide
:
{
projectId
:
dummyProjectId
},
...
props
,
});
};
const
findRows
=
()
=>
wrapper
.
findAll
(
'
tbody tr
'
);
const
findRowAt
=
(
i
)
=>
findRows
().
at
(
i
);
const
findCell
=
(
i
,
col
)
=>
findRowAt
(
i
).
findAll
(
'
td
'
).
at
(
col
);
const
findHeaderAt
=
(
i
)
=>
wrapper
.
findAll
(
'
thead th
'
).
at
(
i
);
const
findPagination
=
()
=>
wrapper
.
findAll
(
'
ul.pagination
'
);
const
findLoadingIcon
=
()
=>
wrapper
.
findComponent
(
GlLoadingIcon
);
describe
(
'
when secure files exist in a project
'
,
()
=>
{
beforeEach
(
async
()
=>
{
mock
=
new
MockAdapter
(
axios
);
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
secureFiles
);
createWrapper
();
await
axios
.
waitForAll
();
});
it
(
'
displays a table with expected headers
'
,
()
=>
{
const
headers
=
[
'
Filename
'
,
'
Permissions
'
,
'
Uploaded
'
];
headers
.
forEach
((
header
,
i
)
=>
{
expect
(
findHeaderAt
(
i
).
text
()).
toBe
(
header
);
});
});
it
(
'
displays a table with rows
'
,
()
=>
{
expect
(
findRows
()).
toHaveLength
(
secureFiles
.
length
);
const
[
secureFile
]
=
secureFiles
;
expect
(
findCell
(
0
,
0
).
text
()).
toBe
(
secureFile
.
name
);
expect
(
findCell
(
0
,
1
).
text
()).
toBe
(
secureFile
.
permissions
);
expect
(
findCell
(
0
,
2
).
find
(
TimeAgoTooltip
).
props
(
'
time
'
)).
toBe
(
secureFile
.
created_at
);
});
});
describe
(
'
when no secure files exist in a project
'
,
()
=>
{
beforeEach
(
async
()
=>
{
mock
=
new
MockAdapter
(
axios
);
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
[]);
createWrapper
();
await
axios
.
waitForAll
();
});
it
(
'
displays a table with expected headers
'
,
()
=>
{
const
headers
=
[
'
Filename
'
,
'
Permissions
'
,
'
Uploaded
'
];
headers
.
forEach
((
header
,
i
)
=>
{
expect
(
findHeaderAt
(
i
).
text
()).
toBe
(
header
);
});
});
it
(
'
displays a table with a no records message
'
,
()
=>
{
expect
(
findCell
(
0
,
0
).
text
()).
toBe
(
'
There are no records to show
'
);
});
});
describe
(
'
pagination
'
,
()
=>
{
it
(
'
displays the pagination component with there are more than 20 items
'
,
async
()
=>
{
mock
=
new
MockAdapter
(
axios
);
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
secureFiles
,
{
'
x-total
'
:
30
});
createWrapper
();
await
axios
.
waitForAll
();
expect
(
findPagination
().
exists
()).
toBe
(
true
);
});
it
(
'
does not display the pagination component with there are 20 items
'
,
async
()
=>
{
mock
=
new
MockAdapter
(
axios
);
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
secureFiles
,
{
'
x-total
'
:
20
});
createWrapper
();
await
axios
.
waitForAll
();
expect
(
findPagination
().
exists
()).
toBe
(
false
);
});
});
describe
(
'
loading state
'
,
()
=>
{
it
(
'
displays the loading icon while waiting for the backend request
'
,
()
=>
{
mock
=
new
MockAdapter
(
axios
);
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
secureFiles
);
createWrapper
();
expect
(
findLoadingIcon
().
exists
()).
toBe
(
true
);
});
it
(
'
does not display the loading icon after the backend request has completed
'
,
async
()
=>
{
mock
=
new
MockAdapter
(
axios
);
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
secureFiles
);
createWrapper
();
await
axios
.
waitForAll
();
expect
(
findLoadingIcon
().
exists
()).
toBe
(
false
);
});
});
});
spec/frontend/ci_secure_files/mock_data.js
0 → 100644
View file @
117ee702
export
const
secureFiles
=
[
{
id
:
1
,
name
:
'
myfile.jks
'
,
checksum
:
'
16630b189ab34b2e3504f4758e1054d2e478deda510b2b08cc0ef38d12e80aac
'
,
checksum_algorithm
:
'
sha256
'
,
permissions
:
'
read_only
'
,
created_at
:
'
2022-02-22T22:22:22.222Z
'
,
},
{
id
:
2
,
name
:
'
myotherfile.jks
'
,
checksum
:
'
16630b189ab34b2e3504f4758e1054d2e478deda510b2b08cc0ef38d12e80aa2
'
,
checksum_algorithm
:
'
sha256
'
,
permissions
:
'
execute
'
,
created_at
:
'
2022-02-22T22:22:22.222Z
'
,
},
];
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment