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
b60d2a0e
Commit
b60d2a0e
authored
Nov 16, 2021
by
Nicolò Maria Mezzopera
Committed by
Natalia Tepluhina
Nov 16, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Detach new and old package registry
parent
eb230448
Changes
20
Show whitespace changes
Inline
Side-by-side
Showing
20 changed files
with
90 additions
and
468 deletions
+90
-468
app/assets/javascripts/packages/list/components/package_search.vue
...s/javascripts/packages/list/components/package_search.vue
+0
-57
app/assets/javascripts/packages/list/components/package_title.vue
...ts/javascripts/packages/list/components/package_title.vue
+0
-47
app/assets/javascripts/packages/list/components/packages_list_app.vue
...avascripts/packages/list/components/packages_list_app.vue
+6
-22
app/assets/javascripts/packages/list/components/tokens/package_type_token.vue
...ts/packages/list/components/tokens/package_type_token.vue
+0
-26
app/assets/javascripts/packages/list/constants.js
app/assets/javascripts/packages/list/constants.js
+0
-6
app/assets/javascripts/packages_and_registries/package_registry/components/functional/delete_package.vue
...package_registry/components/functional/delete_package.vue
+3
-1
app/assets/javascripts/packages_and_registries/package_registry/components/list/app.vue
...s_and_registries/package_registry/components/list/app.vue
+1
-1
app/assets/javascripts/packages_and_registries/package_registry/components/list/package_search.vue
...tries/package_registry/components/list/package_search.vue
+1
-1
app/assets/javascripts/packages_and_registries/package_registry/components/list/package_title.vue
...stries/package_registry/components/list/package_title.vue
+6
-4
app/assets/javascripts/packages_and_registries/package_registry/components/list/tokens/package_type_token.vue
...ge_registry/components/list/tokens/package_type_token.vue
+3
-3
app/assets/javascripts/packages_and_registries/package_registry/constants.js
...pts/packages_and_registries/package_registry/constants.js
+51
-1
app/assets/javascripts/packages_and_registries/package_registry/utils.js
...scripts/packages_and_registries/package_registry/utils.js
+5
-0
spec/frontend/packages/list/components/__snapshots__/packages_list_app_spec.js.snap
...t/components/__snapshots__/packages_list_app_spec.js.snap
+3
-3
spec/frontend/packages/list/components/packages_list_app_spec.js
...ontend/packages/list/components/packages_list_app_spec.js
+4
-41
spec/frontend/packages/list/components/packages_search_spec.js
...frontend/packages/list/components/packages_search_spec.js
+0
-128
spec/frontend/packages/list/components/packages_title_spec.js
.../frontend/packages/list/components/packages_title_spec.js
+0
-71
spec/frontend/packages/list/components/tokens/package_type_token_spec.js
...ackages/list/components/tokens/package_type_token_spec.js
+0
-48
spec/frontend/packages_and_registries/package_registry/components/list/packages_search_spec.js
.../package_registry/components/list/packages_search_spec.js
+1
-1
spec/frontend/packages_and_registries/package_registry/components/list/packages_title_spec.js
...s/package_registry/components/list/packages_title_spec.js
+2
-3
spec/frontend/packages_and_registries/package_registry/components/list/tokens/package_type_token_spec.js
...egistry/components/list/tokens/package_type_token_spec.js
+4
-4
No files found.
app/assets/javascripts/packages/list/components/package_search.vue
deleted
100644 → 0
View file @
eb230448
<
script
>
import
{
mapState
,
mapActions
}
from
'
vuex
'
;
import
{
s__
}
from
'
~/locale
'
;
import
{
OPERATOR_IS_ONLY
}
from
'
~/vue_shared/components/filtered_search_bar/constants
'
;
import
RegistrySearch
from
'
~/vue_shared/components/registry/registry_search.vue
'
;
import
UrlSync
from
'
~/vue_shared/components/url_sync.vue
'
;
import
{
sortableFields
}
from
'
../utils
'
;
import
PackageTypeToken
from
'
./tokens/package_type_token.vue
'
;
export
default
{
tokens
:
[
{
type
:
'
type
'
,
icon
:
'
package
'
,
title
:
s__
(
'
PackageRegistry|Type
'
),
unique
:
true
,
token
:
PackageTypeToken
,
operators
:
OPERATOR_IS_ONLY
,
},
],
components
:
{
RegistrySearch
,
UrlSync
},
computed
:
{
...
mapState
({
isGroupPage
:
(
state
)
=>
state
.
config
.
isGroupPage
,
sorting
:
(
state
)
=>
state
.
sorting
,
filter
:
(
state
)
=>
state
.
filter
,
}),
sortableFields
()
{
return
sortableFields
(
this
.
isGroupPage
);
},
},
methods
:
{
...
mapActions
([
'
setSorting
'
,
'
setFilter
'
]),
updateSorting
(
newValue
)
{
this
.
setSorting
(
newValue
);
this
.
$emit
(
'
update
'
);
},
},
};
</
script
>
<
template
>
<url-sync>
<template
#default
="
{ updateQuery }">
<registry-search
:filter=
"filter"
:sorting=
"sorting"
:tokens=
"$options.tokens"
:sortable-fields=
"sortableFields"
@
sorting:changed=
"updateSorting"
@
filter:changed=
"setFilter"
@
filter:submit=
"$emit('update')"
@
query:changed=
"updateQuery"
/>
</
template
>
</url-sync>
</template>
app/assets/javascripts/packages/list/components/package_title.vue
deleted
100644 → 0
View file @
eb230448
<
script
>
import
{
n__
}
from
'
~/locale
'
;
import
MetadataItem
from
'
~/vue_shared/components/registry/metadata_item.vue
'
;
import
TitleArea
from
'
~/vue_shared/components/registry/title_area.vue
'
;
import
{
LIST_INTRO_TEXT
,
LIST_TITLE_TEXT
}
from
'
../constants
'
;
export
default
{
name
:
'
PackageTitle
'
,
components
:
{
TitleArea
,
MetadataItem
,
},
props
:
{
count
:
{
type
:
Number
,
required
:
false
,
default
:
null
,
},
helpUrl
:
{
type
:
String
,
required
:
true
,
},
},
computed
:
{
showPackageCount
()
{
return
Number
.
isInteger
(
this
.
count
);
},
packageAmountText
()
{
return
n__
(
`%d Package`
,
`%d Packages`
,
this
.
count
);
},
infoMessages
()
{
return
[{
text
:
LIST_INTRO_TEXT
,
link
:
this
.
helpUrl
}];
},
},
i18n
:
{
LIST_TITLE_TEXT
,
},
};
</
script
>
<
template
>
<title-area
:title=
"$options.i18n.LIST_TITLE_TEXT"
:info-messages=
"infoMessages"
>
<template
#metadata-amount
>
<metadata-item
v-if=
"showPackageCount"
icon=
"package"
:text=
"packageAmountText"
/>
</
template
>
</title-area>
</template>
app/assets/javascripts/packages/list/components/packages_list_app.vue
View file @
b60d2a0e
...
...
@@ -7,6 +7,8 @@ import { s__ } from '~/locale';
import
{
SHOW_DELETE_SUCCESS_ALERT
}
from
'
~/packages/shared/constants
'
;
import
{
FILTERED_SEARCH_TERM
}
from
'
~/packages_and_registries/shared/constants
'
;
import
{
getQueryParams
,
extractFilterAndSorting
}
from
'
~/packages_and_registries/shared/utils
'
;
import
InfrastructureTitle
from
'
~/packages_and_registries/infrastructure_registry/components/infrastructure_title.vue
'
;
import
InfrastructureSearch
from
'
~/packages_and_registries/infrastructure_registry/components/infrastructure_search.vue
'
;
import
{
DELETE_PACKAGE_SUCCESS_MESSAGE
}
from
'
../constants
'
;
import
PackageList
from
'
./packages_list.vue
'
;
...
...
@@ -16,28 +18,10 @@ export default {
GlLink
,
GlSprintf
,
PackageList
,
PackageTitle
:
()
=>
import
(
/* webpackChunkName: 'package_registry_components' */
'
./package_title.vue
'
),
PackageSearch
:
()
=>
import
(
/* webpackChunkName: 'package_registry_components' */
'
./package_search.vue
'
),
InfrastructureTitle
:
()
=>
import
(
/* webpackChunkName: 'infrastructure_registry_components' */
'
~/packages_and_registries/infrastructure_registry/components/infrastructure_title.vue
'
),
InfrastructureSearch
:
()
=>
import
(
/* webpackChunkName: 'infrastructure_registry_components' */
'
~/packages_and_registries/infrastructure_registry/components/infrastructure_search.vue
'
),
InfrastructureTitle
,
InfrastructureSearch
,
},
inject
:
{
titleComponent
:
{
from
:
'
titleComponent
'
,
default
:
'
PackageTitle
'
,
},
searchComponent
:
{
from
:
'
searchComponent
'
,
default
:
'
PackageSearch
'
,
},
emptyPageTitle
:
{
from
:
'
emptyPageTitle
'
,
default
:
s__
(
'
PackageRegistry|There are no packages yet
'
),
...
...
@@ -111,8 +95,8 @@ export default {
<
template
>
<div>
<
component
:is=
"titleComponent"
:help-url=
"packageHelpUrl"
:count=
"packagesCount"
/>
<
component
:is=
"searchComponent"
@
update=
"requestPackagesList"
/>
<
infrastructure-title
:help-url=
"packageHelpUrl"
:count=
"packagesCount"
/>
<
infrastructure-search
@
update=
"requestPackagesList"
/>
<package-list
@
page:changed=
"onPageChanged"
@
package:delete=
"onPackageDeleteRequest"
>
<template
#empty-state
>
...
...
app/assets/javascripts/packages/list/components/tokens/package_type_token.vue
deleted
100644 → 0
View file @
eb230448
<
script
>
import
{
GlFilteredSearchToken
,
GlFilteredSearchSuggestion
}
from
'
@gitlab/ui
'
;
import
{
PACKAGE_TYPES
}
from
'
../../constants
'
;
export
default
{
components
:
{
GlFilteredSearchToken
,
GlFilteredSearchSuggestion
,
},
PACKAGE_TYPES
,
};
</
script
>
<
template
>
<gl-filtered-search-token
v-bind=
"
{ ...$attrs }" v-on="$listeners">
<template
#suggestions
>
<gl-filtered-search-suggestion
v-for=
"(type, index) in $options.PACKAGE_TYPES"
:key=
"index"
:value=
"type.type"
>
{{
type
.
title
}}
</gl-filtered-search-suggestion>
</
template
>
</gl-filtered-search-token>
</template>
app/assets/javascripts/packages/list/constants.js
View file @
b60d2a0e
...
...
@@ -96,10 +96,4 @@ export const PACKAGE_TYPES = [
},
];
export
const
LIST_TITLE_TEXT
=
s__
(
'
PackageRegistry|Package Registry
'
);
export
const
LIST_INTRO_TEXT
=
s__
(
'
PackageRegistry|Publish and share packages for a variety of common package managers. %{docLinkStart}More information%{docLinkEnd}
'
,
);
export
const
TERRAFORM_SEARCH_TYPE
=
Object
.
freeze
({
value
:
{
data
:
'
terraform_module
'
}
});
app/assets/javascripts/packages_and_registries/package_registry/components/functional/delete_package.vue
View file @
b60d2a0e
...
...
@@ -3,6 +3,8 @@ import destroyPackageMutation from '~/packages_and_registries/package_registry/g
import
createFlash
from
'
~/flash
'
;
import
{
s__
}
from
'
~/locale
'
;
import
{
DELETE_PACKAGE_SUCCESS_MESSAGE
}
from
'
~/packages_and_registries/package_registry/constants
'
;
export
default
{
props
:
{
refetchQueries
:
{
...
...
@@ -18,7 +20,7 @@ export default {
},
i18n
:
{
errorMessage
:
s__
(
'
PackageRegistry|Something went wrong while deleting the package.
'
),
successMessage
:
s__
(
'
PackageRegistry|Package deleted successfully
'
)
,
successMessage
:
DELETE_PACKAGE_SUCCESS_MESSAGE
,
},
methods
:
{
async
deletePackage
(
packageEntity
)
{
...
...
app/assets/javascripts/packages_and_registries/package_registry/components/list/app.vue
View file @
b60d2a0e
...
...
@@ -3,12 +3,12 @@ import { GlEmptyState, GlLink, GlSprintf } from '@gitlab/ui';
import
createFlash
from
'
~/flash
'
;
import
{
historyReplaceState
}
from
'
~/lib/utils/common_utils
'
;
import
{
s__
}
from
'
~/locale
'
;
import
{
DELETE_PACKAGE_SUCCESS_MESSAGE
}
from
'
~/packages/list/constants
'
;
import
{
SHOW_DELETE_SUCCESS_ALERT
}
from
'
~/packages/shared/constants
'
;
import
{
PROJECT_RESOURCE_TYPE
,
GROUP_RESOURCE_TYPE
,
GRAPHQL_PAGE_SIZE
,
DELETE_PACKAGE_SUCCESS_MESSAGE
,
}
from
'
~/packages_and_registries/package_registry/constants
'
;
import
getPackagesQuery
from
'
~/packages_and_registries/package_registry/graphql/queries/get_packages.query.graphql
'
;
...
...
app/assets/javascripts/packages_and_registries/package_registry/components/list/package_search.vue
View file @
b60d2a0e
<
script
>
import
{
s__
}
from
'
~/locale
'
;
import
{
sortableFields
}
from
'
~/packages
/list
/utils
'
;
import
{
sortableFields
}
from
'
~/packages
_and_registries/package_registry
/utils
'
;
import
{
OPERATOR_IS_ONLY
}
from
'
~/vue_shared/components/filtered_search_bar/constants
'
;
import
RegistrySearch
from
'
~/vue_shared/components/registry/registry_search.vue
'
;
import
UrlSync
from
'
~/vue_shared/components/url_sync.vue
'
;
...
...
app/assets/javascripts/packages_and_registries/package_registry/components/list/package_title.vue
View file @
b60d2a0e
<
script
>
import
{
n__
}
from
'
~/locale
'
;
import
{
LIST_INTRO_TEXT
,
LIST_TITLE_TEXT
}
from
'
~/packages/list/constants
'
;
import
{
n__
,
s__
}
from
'
~/locale
'
;
import
MetadataItem
from
'
~/vue_shared/components/registry/metadata_item.vue
'
;
import
TitleArea
from
'
~/vue_shared/components/registry/title_area.vue
'
;
...
...
@@ -29,11 +28,14 @@ export default {
return
n__
(
`%d Package`
,
`%d Packages`
,
this
.
count
);
},
infoMessages
()
{
return
[{
text
:
LIST_INTRO_TEXT
,
link
:
this
.
helpUrl
}];
return
[{
text
:
this
.
$options
.
i18n
.
LIST_INTRO_TEXT
,
link
:
this
.
helpUrl
}];
},
},
i18n
:
{
LIST_TITLE_TEXT
,
LIST_TITLE_TEXT
:
s__
(
'
PackageRegistry|Package Registry
'
),
LIST_INTRO_TEXT
:
s__
(
'
PackageRegistry|Publish and share packages for a variety of common package managers. %{docLinkStart}More information%{docLinkEnd}
'
,
),
},
};
</
script
>
...
...
app/assets/javascripts/packages_and_registries/package_registry/components/list/tokens/package_type_token.vue
View file @
b60d2a0e
<
script
>
import
{
GlFilteredSearchToken
,
GlFilteredSearchSuggestion
}
from
'
@gitlab/ui
'
;
import
{
PACKAGE_TYPES
}
from
'
~/packages
/list
/constants
'
;
import
{
PACKAGE_TYPES
}
from
'
~/packages
_and_registries/package_registry
/constants
'
;
export
default
{
components
:
{
...
...
@@ -17,9 +17,9 @@ export default {
<gl-filtered-search-suggestion
v-for=
"(type, index) in $options.PACKAGE_TYPES"
:key=
"index"
:value=
"type
.type
"
:value=
"type"
>
{{
type
.
title
}}
{{
type
}}
</gl-filtered-search-suggestion>
</
template
>
</gl-filtered-search-token>
...
...
app/assets/javascripts/packages_and_registries/package_registry/constants.js
View file @
b60d2a0e
import
{
s__
}
from
'
~/locale
'
;
import
{
s__
,
__
}
from
'
~/locale
'
;
export
const
PACKAGE_TYPE_CONAN
=
'
CONAN
'
;
export
const
PACKAGE_TYPE_MAVEN
=
'
MAVEN
'
;
...
...
@@ -70,6 +70,8 @@ export const FETCH_PACKAGE_DETAILS_ERROR_MESSAGE = s__(
'
PackageRegistry|Failed to load the package data
'
,
);
export
const
DELETE_PACKAGE_SUCCESS_MESSAGE
=
s__
(
'
PackageRegistry|Package deleted successfully
'
);
export
const
PACKAGE_ERROR_STATUS
=
'
ERROR
'
;
export
const
PACKAGE_DEFAULT_STATUS
=
'
DEFAULT
'
;
export
const
PACKAGE_HIDDEN_STATUS
=
'
HIDDEN
'
;
...
...
@@ -84,3 +86,51 @@ export const INSTANCE_PACKAGE_ENDPOINT_TYPE = 'instance';
export
const
PROJECT_RESOURCE_TYPE
=
'
project
'
;
export
const
GROUP_RESOURCE_TYPE
=
'
group
'
;
export
const
GRAPHQL_PAGE_SIZE
=
20
;
export
const
LIST_KEY_NAME
=
'
name
'
;
export
const
LIST_KEY_PROJECT
=
'
project_path
'
;
export
const
LIST_KEY_VERSION
=
'
version
'
;
export
const
LIST_KEY_PACKAGE_TYPE
=
'
type
'
;
export
const
LIST_KEY_CREATED_AT
=
'
created_at
'
;
export
const
LIST_LABEL_NAME
=
__
(
'
Name
'
);
export
const
LIST_LABEL_PROJECT
=
__
(
'
Project
'
);
export
const
LIST_LABEL_VERSION
=
__
(
'
Version
'
);
export
const
LIST_LABEL_PACKAGE_TYPE
=
__
(
'
Type
'
);
export
const
LIST_LABEL_CREATED_AT
=
__
(
'
Published
'
);
export
const
SORT_FIELDS
=
[
{
orderBy
:
LIST_KEY_NAME
,
label
:
LIST_LABEL_NAME
,
},
{
orderBy
:
LIST_KEY_PROJECT
,
label
:
LIST_LABEL_PROJECT
,
},
{
orderBy
:
LIST_KEY_VERSION
,
label
:
LIST_LABEL_VERSION
,
},
{
orderBy
:
LIST_KEY_PACKAGE_TYPE
,
label
:
LIST_LABEL_PACKAGE_TYPE
,
},
{
orderBy
:
LIST_KEY_CREATED_AT
,
label
:
LIST_LABEL_CREATED_AT
,
},
];
export
const
PACKAGE_TYPES
=
[
s__
(
'
PackageRegistry|Composer
'
),
s__
(
'
PackageRegistry|Conan
'
),
s__
(
'
PackageRegistry|Generic
'
),
s__
(
'
PackageRegistry|Maven
'
),
s__
(
'
PackageRegistry|npm
'
),
s__
(
'
PackageRegistry|NuGet
'
),
s__
(
'
PackageRegistry|PyPI
'
),
s__
(
'
PackageRegistry|RubyGems
'
),
s__
(
'
PackageRegistry|Debian
'
),
s__
(
'
PackageRegistry|Helm
'
),
];
app/assets/javascripts/packages_and_registries/package_registry/utils.js
View file @
b60d2a0e
...
...
@@ -11,6 +11,8 @@ import {
PACKAGE_TYPE_GENERIC
,
PACKAGE_TYPE_DEBIAN
,
PACKAGE_TYPE_HELM
,
LIST_KEY_PROJECT
,
SORT_FIELDS
,
}
from
'
./constants
'
;
export
const
getPackageTypeLabel
=
(
packageType
)
=>
{
...
...
@@ -41,3 +43,6 @@ export const getPackageTypeLabel = (packageType) => {
};
export
const
packageTypeToTrackCategory
=
(
type
)
=>
`UI::
${
capitalize
(
type
)}
Packages`
;
export
const
sortableFields
=
(
isGroupPage
)
=>
SORT_FIELDS
.
filter
((
f
)
=>
f
.
orderBy
!==
LIST_KEY_PROJECT
||
isGroupPage
);
spec/frontend/packages/list/components/__snapshots__/packages_list_app_spec.js.snap
View file @
b60d2a0e
...
...
@@ -2,11 +2,11 @@
exports[`packages_list_app renders 1`] = `
<div>
<
div
help
-
url="foo"
<
infrastructure-title-stub
helpurl="foo"
/>
<
div
/>
<
infrastructure-search-stub
/>
<div>
<section
...
...
spec/frontend/packages/list/components/packages_list_app_spec.js
View file @
b60d2a0e
...
...
@@ -9,6 +9,7 @@ import { DELETE_PACKAGE_SUCCESS_MESSAGE } from '~/packages/list/constants';
import
{
SHOW_DELETE_SUCCESS_ALERT
}
from
'
~/packages/shared/constants
'
;
import
{
FILTERED_SEARCH_TERM
}
from
'
~/packages_and_registries/shared/constants
'
;
import
*
as
packageUtils
from
'
~/packages_and_registries/shared/utils
'
;
import
InfrastructureSearch
from
'
~/packages_and_registries/infrastructure_registry/components/infrastructure_search.vue
'
;
jest
.
mock
(
'
~/lib/utils/common_utils
'
);
jest
.
mock
(
'
~/flash
'
);
...
...
@@ -26,18 +27,9 @@ describe('packages_list_app', () => {
};
const
GlLoadingIcon
=
{
name
:
'
gl-loading-icon
'
,
template
:
'
<div>loading</div>
'
};
// we need to manually stub dynamic imported components because shallowMount is not able to stub them automatically. See: https://github.com/vuejs/vue-test-utils/issues/1279
const
PackageSearch
=
{
name
:
'
PackageSearch
'
,
template
:
'
<div></div>
'
};
const
PackageTitle
=
{
name
:
'
PackageTitle
'
,
template
:
'
<div></div>
'
};
const
InfrastructureTitle
=
{
name
:
'
InfrastructureTitle
'
,
template
:
'
<div></div>
'
};
const
InfrastructureSearch
=
{
name
:
'
InfrastructureSearch
'
,
template
:
'
<div></div>
'
};
const
emptyListHelpUrl
=
'
helpUrl
'
;
const
findEmptyState
=
()
=>
wrapper
.
find
(
GlEmptyState
);
const
findListComponent
=
()
=>
wrapper
.
find
(
PackageList
);
const
findPackageSearch
=
()
=>
wrapper
.
find
(
PackageSearch
);
const
findPackageTitle
=
()
=>
wrapper
.
find
(
PackageTitle
);
const
findInfrastructureTitle
=
()
=>
wrapper
.
find
(
InfrastructureTitle
);
const
findInfrastructureSearch
=
()
=>
wrapper
.
find
(
InfrastructureSearch
);
const
createStore
=
(
filter
=
[])
=>
{
...
...
@@ -66,10 +58,6 @@ describe('packages_list_app', () => {
PackageList
,
GlSprintf
,
GlLink
,
PackageSearch
,
PackageTitle
,
InfrastructureTitle
,
InfrastructureSearch
,
},
provide
,
});
...
...
@@ -191,48 +179,23 @@ describe('packages_list_app', () => {
});
});
describe
(
'
Package
Search
'
,
()
=>
{
describe
(
'
Search
'
,
()
=>
{
it
(
'
exists
'
,
()
=>
{
mountComponent
();
expect
(
find
Packag
eSearch
().
exists
()).
toBe
(
true
);
expect
(
find
Infrastructur
eSearch
().
exists
()).
toBe
(
true
);
});
it
(
'
on update fetches data from the store
'
,
()
=>
{
mountComponent
();
store
.
dispatch
.
mockClear
();
find
Packag
eSearch
().
vm
.
$emit
(
'
update
'
);
find
Infrastructur
eSearch
().
vm
.
$emit
(
'
update
'
);
expect
(
store
.
dispatch
).
toHaveBeenCalledWith
(
'
requestPackagesList
'
);
});
});
describe
(
'
Infrastructure config
'
,
()
=>
{
it
(
'
defaults to package registry components
'
,
()
=>
{
mountComponent
();
expect
(
findPackageSearch
().
exists
()).
toBe
(
true
);
expect
(
findPackageTitle
().
exists
()).
toBe
(
true
);
expect
(
findInfrastructureTitle
().
exists
()).
toBe
(
false
);
expect
(
findInfrastructureSearch
().
exists
()).
toBe
(
false
);
});
it
(
'
mount different component based on the provided values
'
,
()
=>
{
mountComponent
({
titleComponent
:
'
InfrastructureTitle
'
,
searchComponent
:
'
InfrastructureSearch
'
,
});
expect
(
findPackageSearch
().
exists
()).
toBe
(
false
);
expect
(
findPackageTitle
().
exists
()).
toBe
(
false
);
expect
(
findInfrastructureTitle
().
exists
()).
toBe
(
true
);
expect
(
findInfrastructureSearch
().
exists
()).
toBe
(
true
);
});
});
describe
(
'
delete alert handling
'
,
()
=>
{
const
originalLocation
=
window
.
location
.
href
;
const
search
=
`?
${
SHOW_DELETE_SUCCESS_ALERT
}
=true`
;
...
...
spec/frontend/packages/list/components/packages_search_spec.js
deleted
100644 → 0
View file @
eb230448
import
{
shallowMount
,
createLocalVue
}
from
'
@vue/test-utils
'
;
import
Vuex
from
'
vuex
'
;
import
component
from
'
~/packages/list/components/package_search.vue
'
;
import
PackageTypeToken
from
'
~/packages/list/components/tokens/package_type_token.vue
'
;
import
{
sortableFields
}
from
'
~/packages/list/utils
'
;
import
RegistrySearch
from
'
~/vue_shared/components/registry/registry_search.vue
'
;
import
UrlSync
from
'
~/vue_shared/components/url_sync.vue
'
;
const
localVue
=
createLocalVue
();
localVue
.
use
(
Vuex
);
describe
(
'
Package Search
'
,
()
=>
{
let
wrapper
;
let
store
;
const
findRegistrySearch
=
()
=>
wrapper
.
findComponent
(
RegistrySearch
);
const
findUrlSync
=
()
=>
wrapper
.
findComponent
(
UrlSync
);
const
createStore
=
(
isGroupPage
)
=>
{
const
state
=
{
config
:
{
isGroupPage
,
},
sorting
:
{
orderBy
:
'
version
'
,
sort
:
'
desc
'
,
},
filter
:
[],
};
store
=
new
Vuex
.
Store
({
state
,
});
store
.
dispatch
=
jest
.
fn
();
};
const
mountComponent
=
(
isGroupPage
=
false
)
=>
{
createStore
(
isGroupPage
);
wrapper
=
shallowMount
(
component
,
{
localVue
,
store
,
stubs
:
{
UrlSync
,
},
});
};
afterEach
(()
=>
{
wrapper
.
destroy
();
wrapper
=
null
;
});
it
(
'
has a registry search component
'
,
()
=>
{
mountComponent
();
expect
(
findRegistrySearch
().
exists
()).
toBe
(
true
);
expect
(
findRegistrySearch
().
props
()).
toMatchObject
({
filter
:
store
.
state
.
filter
,
sorting
:
store
.
state
.
sorting
,
tokens
:
expect
.
arrayContaining
([
expect
.
objectContaining
({
token
:
PackageTypeToken
,
type
:
'
type
'
,
icon
:
'
package
'
}),
]),
sortableFields
:
sortableFields
(),
});
});
it
.
each
`
isGroupPage | page
${
false
}
|
${
'
project
'
}
${
true
}
|
${
'
group
'
}
`
(
'
in a $page page binds the right props
'
,
({
isGroupPage
})
=>
{
mountComponent
(
isGroupPage
);
expect
(
findRegistrySearch
().
props
()).
toMatchObject
({
filter
:
store
.
state
.
filter
,
sorting
:
store
.
state
.
sorting
,
tokens
:
expect
.
arrayContaining
([
expect
.
objectContaining
({
token
:
PackageTypeToken
,
type
:
'
type
'
,
icon
:
'
package
'
}),
]),
sortableFields
:
sortableFields
(
isGroupPage
),
});
});
it
(
'
on sorting:changed emits update event and calls vuex setSorting
'
,
()
=>
{
const
payload
=
{
sort
:
'
foo
'
};
mountComponent
();
findRegistrySearch
().
vm
.
$emit
(
'
sorting:changed
'
,
payload
);
expect
(
store
.
dispatch
).
toHaveBeenCalledWith
(
'
setSorting
'
,
payload
);
expect
(
wrapper
.
emitted
(
'
update
'
)).
toEqual
([[]]);
});
it
(
'
on filter:changed calls vuex setFilter
'
,
()
=>
{
const
payload
=
[
'
foo
'
];
mountComponent
();
findRegistrySearch
().
vm
.
$emit
(
'
filter:changed
'
,
payload
);
expect
(
store
.
dispatch
).
toHaveBeenCalledWith
(
'
setFilter
'
,
payload
);
});
it
(
'
on filter:submit emits update event
'
,
()
=>
{
mountComponent
();
findRegistrySearch
().
vm
.
$emit
(
'
filter:submit
'
);
expect
(
wrapper
.
emitted
(
'
update
'
)).
toEqual
([[]]);
});
it
(
'
has a UrlSync component
'
,
()
=>
{
mountComponent
();
expect
(
findUrlSync
().
exists
()).
toBe
(
true
);
});
it
(
'
on query:changed calls updateQuery from UrlSync
'
,
()
=>
{
jest
.
spyOn
(
UrlSync
.
methods
,
'
updateQuery
'
).
mockImplementation
(()
=>
{});
mountComponent
();
findRegistrySearch
().
vm
.
$emit
(
'
query:changed
'
);
expect
(
UrlSync
.
methods
.
updateQuery
).
toHaveBeenCalled
();
});
});
spec/frontend/packages/list/components/packages_title_spec.js
deleted
100644 → 0
View file @
eb230448
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
LIST_INTRO_TEXT
,
LIST_TITLE_TEXT
}
from
'
~/packages/list//constants
'
;
import
PackageTitle
from
'
~/packages/list/components/package_title.vue
'
;
import
MetadataItem
from
'
~/vue_shared/components/registry/metadata_item.vue
'
;
import
TitleArea
from
'
~/vue_shared/components/registry/title_area.vue
'
;
describe
(
'
PackageTitle
'
,
()
=>
{
let
wrapper
;
let
store
;
const
findTitleArea
=
()
=>
wrapper
.
find
(
TitleArea
);
const
findMetadataItem
=
()
=>
wrapper
.
find
(
MetadataItem
);
const
mountComponent
=
(
propsData
=
{
helpUrl
:
'
foo
'
})
=>
{
wrapper
=
shallowMount
(
PackageTitle
,
{
store
,
propsData
,
stubs
:
{
TitleArea
,
},
});
};
afterEach
(()
=>
{
wrapper
.
destroy
();
wrapper
=
null
;
});
describe
(
'
title area
'
,
()
=>
{
it
(
'
exists
'
,
()
=>
{
mountComponent
();
expect
(
findTitleArea
().
exists
()).
toBe
(
true
);
});
it
(
'
has the correct props
'
,
()
=>
{
mountComponent
();
expect
(
findTitleArea
().
props
()).
toMatchObject
({
title
:
LIST_TITLE_TEXT
,
infoMessages
:
[{
text
:
LIST_INTRO_TEXT
,
link
:
'
foo
'
}],
});
});
});
describe
.
each
`
count | exist | text
${
null
}
|
${
false
}
|
${
''
}
${
undefined
}
|
${
false
}
|
${
''
}
${
0
}
|
${
true
}
|
${
'
0 Packages
'
}
${
1
}
|
${
true
}
|
${
'
1 Package
'
}
${
2
}
|
${
true
}
|
${
'
2 Packages
'
}
`
(
'
when count is $count metadata item
'
,
({
count
,
exist
,
text
})
=>
{
beforeEach
(()
=>
{
mountComponent
({
count
,
helpUrl
:
'
foo
'
});
});
it
(
`is
${
exist
}
that it exists`
,
()
=>
{
expect
(
findMetadataItem
().
exists
()).
toBe
(
exist
);
});
if
(
exist
)
{
it
(
'
has the correct props
'
,
()
=>
{
expect
(
findMetadataItem
().
props
()).
toMatchObject
({
icon
:
'
package
'
,
text
,
});
});
}
});
});
spec/frontend/packages/list/components/tokens/package_type_token_spec.js
deleted
100644 → 0
View file @
eb230448
import
{
GlFilteredSearchToken
,
GlFilteredSearchSuggestion
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
component
from
'
~/packages/list/components/tokens/package_type_token.vue
'
;
import
{
PACKAGE_TYPES
}
from
'
~/packages/list/constants
'
;
describe
(
'
packages_filter
'
,
()
=>
{
let
wrapper
;
const
findFilteredSearchToken
=
()
=>
wrapper
.
find
(
GlFilteredSearchToken
);
const
findFilteredSearchSuggestions
=
()
=>
wrapper
.
findAll
(
GlFilteredSearchSuggestion
);
const
mountComponent
=
({
attrs
,
listeners
}
=
{})
=>
{
wrapper
=
shallowMount
(
component
,
{
attrs
,
listeners
,
});
};
afterEach
(()
=>
{
wrapper
.
destroy
();
wrapper
=
null
;
});
it
(
'
it binds all of his attrs to filtered search token
'
,
()
=>
{
mountComponent
({
attrs
:
{
foo
:
'
bar
'
}
});
expect
(
findFilteredSearchToken
().
attributes
(
'
foo
'
)).
toBe
(
'
bar
'
);
});
it
(
'
it binds all of his events to filtered search token
'
,
()
=>
{
const
clickListener
=
jest
.
fn
();
mountComponent
({
listeners
:
{
click
:
clickListener
}
});
findFilteredSearchToken
().
vm
.
$emit
(
'
click
'
);
expect
(
clickListener
).
toHaveBeenCalled
();
});
it
.
each
(
PACKAGE_TYPES
.
map
((
p
,
index
)
=>
[
p
,
index
]))(
'
displays a suggestion for %p
'
,
(
packageType
,
index
)
=>
{
mountComponent
();
const
item
=
findFilteredSearchSuggestions
().
at
(
index
);
expect
(
item
.
text
()).
toBe
(
packageType
.
title
);
expect
(
item
.
props
(
'
value
'
)).
toBe
(
packageType
.
type
);
},
);
});
spec/frontend/packages_and_registries/package_registry/components/list/packages_search_spec.js
View file @
b60d2a0e
import
{
nextTick
}
from
'
vue
'
;
import
{
shallowMountExtended
}
from
'
helpers/vue_test_utils_helper
'
;
import
{
sortableFields
}
from
'
~/packages
/list
/utils
'
;
import
{
sortableFields
}
from
'
~/packages
_and_registries/package_registry
/utils
'
;
import
component
from
'
~/packages_and_registries/package_registry/components/list/package_search.vue
'
;
import
PackageTypeToken
from
'
~/packages_and_registries/package_registry/components/list/tokens/package_type_token.vue
'
;
import
RegistrySearch
from
'
~/vue_shared/components/registry/registry_search.vue
'
;
...
...
spec/frontend/packages_and_registries/package_registry/components/list/packages_title_spec.js
View file @
b60d2a0e
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
LIST_INTRO_TEXT
,
LIST_TITLE_TEXT
}
from
'
~/packages/list/constants
'
;
import
PackageTitle
from
'
~/packages_and_registries/package_registry/components/list/package_title.vue
'
;
import
MetadataItem
from
'
~/vue_shared/components/registry/metadata_item.vue
'
;
import
TitleArea
from
'
~/vue_shared/components/registry/title_area.vue
'
;
...
...
@@ -37,8 +36,8 @@ describe('PackageTitle', () => {
mountComponent
();
expect
(
findTitleArea
().
props
()).
toMatchObject
({
title
:
LIST_TITLE_TEXT
,
infoMessages
:
[{
text
:
LIST_INTRO_TEXT
,
link
:
'
foo
'
}],
title
:
PackageTitle
.
i18n
.
LIST_TITLE_TEXT
,
infoMessages
:
[{
text
:
PackageTitle
.
i18n
.
LIST_INTRO_TEXT
,
link
:
'
foo
'
}],
});
});
});
...
...
spec/frontend/packages_and_registries/package_registry/components/list/tokens/package_type_token_spec.js
View file @
b60d2a0e
import
{
GlFilteredSearchToken
,
GlFilteredSearchSuggestion
}
from
'
@gitlab/ui
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
component
from
'
~/packages
/list/components
/tokens/package_type_token.vue
'
;
import
{
PACKAGE_TYPES
}
from
'
~/packages
/list
/constants
'
;
import
component
from
'
~/packages
_and_registries/package_registry/components/list
/tokens/package_type_token.vue
'
;
import
{
PACKAGE_TYPES
}
from
'
~/packages
_and_registries/package_registry
/constants
'
;
describe
(
'
packages_filter
'
,
()
=>
{
let
wrapper
;
...
...
@@ -41,8 +41,8 @@ describe('packages_filter', () => {
(
packageType
,
index
)
=>
{
mountComponent
();
const
item
=
findFilteredSearchSuggestions
().
at
(
index
);
expect
(
item
.
text
()).
toBe
(
packageType
.
title
);
expect
(
item
.
props
(
'
value
'
)).
toBe
(
packageType
.
type
);
expect
(
item
.
text
()).
toBe
(
packageType
);
expect
(
item
.
props
(
'
value
'
)).
toBe
(
packageType
);
},
);
});
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