diff --git a/ui/app/utils/generate-exec-url.js b/ui/app/utils/generate-exec-url.js index f4740d15d88..a5b5d0fb723 100644 --- a/ui/app/utils/generate-exec-url.js +++ b/ui/app/utils/generate-exec-url.js @@ -1,7 +1,18 @@ import { get } from '@ember/object'; export default function generateExecUrl(router, { job, taskGroup, task, allocation }) { - const queryParams = router.currentRoute.queryParams; + const queryParams = {}; + + const namespace = get(job, 'namespace.name'); + const region = get(job, 'region'); + + if (namespace) { + queryParams.namespace = namespace; + } + + if (region) { + queryParams.region = region; + } if (task) { const queryParamsOptions = { diff --git a/ui/tests/unit/utils/generate-exec-url-test.js b/ui/tests/unit/utils/generate-exec-url-test.js index 6be39412ddd..b2897cc4e8d 100644 --- a/ui/tests/unit/utils/generate-exec-url-test.js +++ b/ui/tests/unit/utils/generate-exec-url-test.js @@ -96,14 +96,15 @@ module('Unit | Utility | generate-exec-url', function(hooks) { ); }); - test('it includes query parameters from the current route', function(assert) { - this.router.currentRoute.queryParams = { - namespace: 'a-namespace', - region: 'a-region', - }; - + test('it includes job namespace and region when they exist', function(assert) { generateExecUrl(this.router, { - job: { plainId: 'job-name' }, + job: { + namespace: { + name: 'a-namespace', + }, + plainId: 'job-name', + region: 'a-region', + }, allocation: { shortId: 'id', taskGroup: { name: 'task-group-name', tasks: [0, 1] } }, });