Commit ff35d68b authored by Coung Ngo's avatar Coung Ngo Committed by Vitaly Slobodin

Fix Jira importer user mapping limit

The Jira importer user mapping shows up to 50 users, so any
users cannot see all users if their project has more than
50 users. This commit fixes this issue.
parent 75bc2125
...@@ -23,6 +23,7 @@ import { addInProgressImportToStore } from '../utils/cache_update'; ...@@ -23,6 +23,7 @@ import { addInProgressImportToStore } from '../utils/cache_update';
import { import {
debounceWait, debounceWait,
dropdownLabel, dropdownLabel,
userMappingsPageSize,
previousImportsMessage, previousImportsMessage,
tableConfig, tableConfig,
userMappingMessage, userMappingMessage,
...@@ -74,12 +75,15 @@ export default { ...@@ -74,12 +75,15 @@ export default {
}, },
data() { data() {
return { return {
hasMoreUsers: false,
isFetching: false, isFetching: false,
isLoadingMoreUsers: false,
isSubmitting: false, isSubmitting: false,
searchTerm: '', searchTerm: '',
selectedProject: undefined, selectedProject: undefined,
selectState: null, selectState: null,
userMappings: [], userMappings: [],
userMappingsStartAt: 0,
users: [], users: [],
}; };
}, },
...@@ -101,6 +105,9 @@ export default { ...@@ -101,6 +105,9 @@ export default {
? `jira-import::${this.selectedProject}-${this.numberOfPreviousImports + 1}` ? `jira-import::${this.selectedProject}-${this.numberOfPreviousImports + 1}`
: 'jira-import::KEY-1'; : 'jira-import::KEY-1';
}, },
isInitialLoadingState() {
return this.isLoadingMoreUsers && !this.hasMoreUsers;
},
}, },
watch: { watch: {
searchTerm: debounce(function debouncedUserSearch() { searchTerm: debounce(function debouncedUserSearch() {
...@@ -108,31 +115,45 @@ export default { ...@@ -108,31 +115,45 @@ export default {
}, debounceWait), }, debounceWait),
}, },
mounted() { mounted() {
this.getJiraUserMapping();
this.searchUsers()
.then(data => {
this.initialUsers = data;
})
.catch(() => {});
},
methods: {
getJiraUserMapping() {
this.isLoadingMoreUsers = true;
this.$apollo this.$apollo
.mutate({ .mutate({
mutation: getJiraUserMappingMutation, mutation: getJiraUserMappingMutation,
variables: { variables: {
input: { input: {
projectPath: this.projectPath, projectPath: this.projectPath,
startAt: this.userMappingsStartAt,
}, },
}, },
}) })
.then(({ data }) => { .then(({ data }) => {
if (data.jiraImportUsers.errors.length) { if (data.jiraImportUsers.errors.length) {
this.$emit('error', data.jiraImportUsers.errors.join('. ')); this.$emit('error', data.jiraImportUsers.errors.join('. '));
} else { return;
this.userMappings = data.jiraImportUsers.jiraUsers;
} }
})
.catch(() => this.$emit('error', __('There was an error retrieving the Jira users.')));
this.searchUsers() this.userMappings = this.userMappings.concat(data.jiraImportUsers.jiraUsers);
.then(data => { this.hasMoreUsers = data.jiraImportUsers.jiraUsers.length === userMappingsPageSize;
this.initialUsers = data; this.userMappingsStartAt += userMappingsPageSize;
}) })
.catch(() => {}); .catch(() => {
this.$emit('error', __('There was an error retrieving the Jira users.'));
})
.finally(() => {
this.isLoadingMoreUsers = false;
});
}, },
methods: {
searchUsers() { searchUsers() {
const params = { const params = {
active: true, active: true,
...@@ -187,7 +208,9 @@ export default { ...@@ -187,7 +208,9 @@ export default {
this.selectedProject = undefined; this.selectedProject = undefined;
} }
}) })
.catch(() => this.$emit('error', __('There was an error importing the Jira project.'))) .catch(() => {
this.$emit('error', __('There was an error importing the Jira project.'));
})
.finally(() => { .finally(() => {
this.isSubmitting = false; this.isSubmitting = false;
}); });
...@@ -280,9 +303,7 @@ export default { ...@@ -280,9 +303,7 @@ export default {
> >
<gl-search-box-by-type v-model.trim="searchTerm" class="m-2" /> <gl-search-box-by-type v-model.trim="searchTerm" class="m-2" />
<div v-if="isFetching" class="gl-text-center"> <gl-loading-icon v-if="isFetching" />
<gl-loading-icon />
</div>
<gl-new-dropdown-item <gl-new-dropdown-item
v-for="user in users" v-for="user in users"
...@@ -300,6 +321,17 @@ export default { ...@@ -300,6 +321,17 @@ export default {
</template> </template>
</gl-table> </gl-table>
<gl-loading-icon v-if="isInitialLoadingState" />
<gl-button
v-if="hasMoreUsers"
:loading="isLoadingMoreUsers"
data-testid="load-more-users-button"
@click="getJiraUserMapping"
>
{{ __('Load more users') }}
</gl-button>
<div class="footer-block row-content-block d-flex justify-content-between"> <div class="footer-block row-content-block d-flex justify-content-between">
<gl-button <gl-button
type="submit" type="submit"
......
...@@ -27,3 +27,6 @@ export const tableConfig = [ ...@@ -27,3 +27,6 @@ export const tableConfig = [
export const userMappingMessage = __(`Jira users have been imported from the configured Jira export const userMappingMessage = __(`Jira users have been imported from the configured Jira
instance. They can be mapped by selecting a GitLab user from the dropdown in the "GitLab username" instance. They can be mapped by selecting a GitLab user from the dropdown in the "GitLab username"
column. When the form appears, the dropdown defaults to the user conducting the import.`); column. When the form appears, the dropdown defaults to the user conducting the import.`);
// pageSize must match the MAX_USERS value in app/services/jira_import/users_mapper_service.rb
export const userMappingsPageSize = 50;
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
module JiraImport module JiraImport
class UsersMapperService class UsersMapperService
# MAX_USERS must match the pageSize value in app/assets/javascripts/jira_import/utils/constants.js
MAX_USERS = 50 MAX_USERS = 50
attr_reader :jira_service, :start_at attr_reader :jira_service, :start_at
......
---
title: Fix Jira importer user mapping limit
merge_request: 40310
author:
type: fixed
...@@ -14594,6 +14594,9 @@ msgstr "" ...@@ -14594,6 +14594,9 @@ msgstr ""
msgid "Load more" msgid "Load more"
msgstr "" msgstr ""
msgid "Load more users"
msgstr ""
msgid "Loading" msgid "Loading"
msgstr "" msgstr ""
......
...@@ -10,6 +10,7 @@ import { ...@@ -10,6 +10,7 @@ import {
imports, imports,
issuesPath, issuesPath,
jiraProjects, jiraProjects,
jiraUsersResponse,
projectId, projectId,
projectPath, projectPath,
userMappings as defaultUserMappings, userMappings as defaultUserMappings,
...@@ -38,7 +39,10 @@ describe('JiraImportForm', () => { ...@@ -38,7 +39,10 @@ describe('JiraImportForm', () => {
const getHeader = name => getByRole(wrapper.element, 'columnheader', { name }); const getHeader = name => getByRole(wrapper.element, 'columnheader', { name });
const findLoadMoreUsersButton = () => wrapper.find('[data-testid="load-more-users-button"]');
const mountComponent = ({ const mountComponent = ({
hasMoreUsers = false,
isSubmitting = false, isSubmitting = false,
loading = false, loading = false,
mutate = mutateSpy, mutate = mutateSpy,
...@@ -55,6 +59,7 @@ describe('JiraImportForm', () => { ...@@ -55,6 +59,7 @@ describe('JiraImportForm', () => {
projectPath, projectPath,
}, },
data: () => ({ data: () => ({
hasMoreUsers,
isFetching: false, isFetching: false,
isSubmitting, isSubmitting,
searchTerm: '', searchTerm: '',
...@@ -300,6 +305,7 @@ describe('JiraImportForm', () => { ...@@ -300,6 +305,7 @@ describe('JiraImportForm', () => {
variables: { variables: {
input: { input: {
projectPath, projectPath,
startAt: 0,
}, },
}, },
}; };
...@@ -318,4 +324,53 @@ describe('JiraImportForm', () => { ...@@ -318,4 +324,53 @@ describe('JiraImportForm', () => {
}); });
}); });
}); });
describe('load more users button', () => {
describe('when all users have been loaded', () => {
it('is not shown', () => {
wrapper = mountComponent();
expect(findLoadMoreUsersButton().exists()).toBe(false);
});
});
describe('when all users have not been loaded', () => {
it('is shown', () => {
wrapper = mountComponent({ hasMoreUsers: true });
expect(findLoadMoreUsersButton().exists()).toBe(true);
});
});
describe('when clicked', () => {
beforeEach(() => {
mutateSpy = jest.fn(() =>
Promise.resolve({
data: {
jiraImportStart: { errors: [] },
jiraImportUsers: { jiraUsers: jiraUsersResponse, errors: [] },
},
}),
);
wrapper = mountComponent({ hasMoreUsers: true });
});
it('calls the GraphQL user mapping mutation', async () => {
const mutationArguments = {
mutation: getJiraUserMappingMutation,
variables: {
input: {
projectPath,
startAt: 0,
},
},
};
findLoadMoreUsersButton().vm.$emit('click');
expect(mutateSpy).toHaveBeenCalledWith(expect.objectContaining(mutationArguments));
});
});
});
}); });
import getJiraImportDetailsQuery from '~/jira_import/queries/get_jira_import_details.query.graphql'; import getJiraImportDetailsQuery from '~/jira_import/queries/get_jira_import_details.query.graphql';
import { IMPORT_STATE } from '~/jira_import/utils/jira_import_utils'; import { IMPORT_STATE } from '~/jira_import/utils/jira_import_utils';
import { userMappingsPageSize } from '~/jira_import/utils/constants';
export const fullPath = 'gitlab-org/gitlab-test'; export const fullPath = 'gitlab-org/gitlab-test';
...@@ -87,6 +88,8 @@ export const jiraProjects = [ ...@@ -87,6 +88,8 @@ export const jiraProjects = [
{ text: 'Migrate to GitLab (MTG)', value: 'MTG' }, { text: 'Migrate to GitLab (MTG)', value: 'MTG' },
]; ];
export const jiraUsersResponse = new Array(userMappingsPageSize);
export const imports = [ export const imports = [
{ {
jiraProjectKey: 'MTG', jiraProjectKey: 'MTG',
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment