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
9af1773f
Commit
9af1773f
authored
Jan 25, 2018
by
Phil Hughes
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Converted API.js to axios
parent
364395b3
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
102 additions
and
200 deletions
+102
-200
app/assets/javascripts/api.js
app/assets/javascripts/api.js
+38
-77
app/assets/javascripts/ide/stores/actions.js
app/assets/javascripts/ide/stores/actions.js
+3
-3
app/assets/javascripts/ide/stores/actions/branch.js
app/assets/javascripts/ide/stores/actions/branch.js
+1
-1
app/assets/javascripts/lib/utils/users_cache.js
app/assets/javascripts/lib/utils/users_cache.js
+4
-4
spec/javascripts/api_spec.js
spec/javascripts/api_spec.js
+56
-115
No files found.
app/assets/javascripts/api.js
View file @
9af1773f
import
$
from
'
jquery
'
;
import
axios
from
'
./lib/utils/axios_utils
'
;
import
axios
from
'
./lib/utils/axios_utils
'
;
const
Api
=
{
const
Api
=
{
...
@@ -23,38 +22,32 @@ const Api = {
...
@@ -23,38 +22,32 @@ const Api = {
group
(
groupId
,
callback
)
{
group
(
groupId
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
groupPath
)
const
url
=
Api
.
buildUrl
(
Api
.
groupPath
)
.
replace
(
'
:id
'
,
groupId
);
.
replace
(
'
:id
'
,
groupId
);
return
$
.
ajax
({
return
axios
.
get
(
url
)
url
,
.
then
(({
data
})
=>
callback
(
data
));
dataType
:
'
json
'
,
})
.
done
(
group
=>
callback
(
group
));
},
},
// Return groups list. Filtered by query
// Return groups list. Filtered by query
groups
(
query
,
options
,
callback
)
{
groups
(
query
,
options
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
groupsPath
);
const
url
=
Api
.
buildUrl
(
Api
.
groupsPath
);
return
$
.
ajax
({
return
axios
.
get
(
url
,
{
url
,
params
:
Object
.
assign
({
data
:
Object
.
assign
({
search
:
query
,
search
:
query
,
per_page
:
20
,
per_page
:
20
,
},
options
),
},
options
),
dataType
:
'
json
'
,
})
})
.
done
(
groups
=>
callback
(
groups
));
.
then
(({
data
})
=>
callback
(
data
));
},
},
// Return namespaces list. Filtered by query
// Return namespaces list. Filtered by query
namespaces
(
query
,
callback
)
{
namespaces
(
query
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
namespacesPath
);
const
url
=
Api
.
buildUrl
(
Api
.
namespacesPath
);
return
$
.
ajax
({
return
axios
.
get
(
url
,
{
url
,
params
:
{
data
:
{
search
:
query
,
search
:
query
,
per_page
:
20
,
per_page
:
20
,
},
},
dataType
:
'
json
'
,
})
}).
done
(
namespaces
=>
callback
(
namespaces
));
.
then
(({
data
})
=>
callback
(
data
));
},
},
// Return projects list. Filtered by query
// Return projects list. Filtered by query
...
@@ -70,12 +63,10 @@ const Api = {
...
@@ -70,12 +63,10 @@ const Api = {
defaults
.
membership
=
true
;
defaults
.
membership
=
true
;
}
}
return
$
.
ajax
({
return
axios
.
get
(
url
,
{
url
,
params
:
Object
.
assign
(
defaults
,
options
),
data
:
Object
.
assign
(
defaults
,
options
),
dataType
:
'
json
'
,
})
})
.
done
(
projects
=>
callback
(
projects
));
.
then
(({
data
})
=>
callback
(
data
));
},
},
// Return single project
// Return single project
...
@@ -97,41 +88,34 @@ const Api = {
...
@@ -97,41 +88,34 @@ const Api = {
url
=
Api
.
buildUrl
(
Api
.
groupLabelsPath
).
replace
(
'
:namespace_path
'
,
namespacePath
);
url
=
Api
.
buildUrl
(
Api
.
groupLabelsPath
).
replace
(
'
:namespace_path
'
,
namespacePath
);
}
}
return
$
.
ajax
({
return
axios
.
post
(
url
,
{
url
,
label
:
data
,
type
:
'
POST
'
,
data
:
{
label
:
data
},
dataType
:
'
json
'
,
})
})
.
done
(
label
=>
callback
(
label
))
.
then
(
res
=>
callback
(
res
.
data
))
.
fail
(
message
=>
callback
(
message
.
responseJSON
));
.
catch
(
e
=>
callback
(
e
.
response
.
data
));
},
},
// Return group projects list. Filtered by query
// Return group projects list. Filtered by query
groupProjects
(
groupId
,
query
,
callback
)
{
groupProjects
(
groupId
,
query
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
groupProjectsPath
)
const
url
=
Api
.
buildUrl
(
Api
.
groupProjectsPath
)
.
replace
(
'
:id
'
,
groupId
);
.
replace
(
'
:id
'
,
groupId
);
return
$
.
ajax
({
return
axios
.
get
(
url
,
{
url
,
params
:
{
data
:
{
search
:
query
,
search
:
query
,
per_page
:
20
,
per_page
:
20
,
},
},
dataType
:
'
json
'
,
})
})
.
done
(
projects
=>
callback
(
projects
));
.
then
(({
data
})
=>
callback
(
data
));
},
},
commitMultiple
(
id
,
data
)
{
commitMultiple
(
id
,
data
)
{
// see https://docs.gitlab.com/ce/api/commits.html#create-a-commit-with-multiple-files-and-actions
// see https://docs.gitlab.com/ce/api/commits.html#create-a-commit-with-multiple-files-and-actions
const
url
=
Api
.
buildUrl
(
Api
.
commitPath
)
const
url
=
Api
.
buildUrl
(
Api
.
commitPath
)
.
replace
(
'
:id
'
,
encodeURIComponent
(
id
));
.
replace
(
'
:id
'
,
encodeURIComponent
(
id
));
return
this
.
wrapAjaxCall
({
return
axios
.
post
(
url
,
JSON
.
stringify
(
data
),
{
url
,
headers
:
{
type
:
'
POST
'
,
'
Content-Type
'
:
'
application/json; charset=utf-8
'
,
contentType
:
'
application/json; charset=utf-8
'
,
},
data
:
JSON
.
stringify
(
data
),
dataType
:
'
json
'
,
});
});
},
},
...
@@ -140,40 +124,37 @@ const Api = {
...
@@ -140,40 +124,37 @@ const Api = {
.
replace
(
'
:id
'
,
encodeURIComponent
(
id
))
.
replace
(
'
:id
'
,
encodeURIComponent
(
id
))
.
replace
(
'
:branch
'
,
branch
);
.
replace
(
'
:branch
'
,
branch
);
return
this
.
wrapAjaxCall
({
return
axios
.
get
(
url
);
url
,
type
:
'
GET
'
,
contentType
:
'
application/json; charset=utf-8
'
,
dataType
:
'
json
'
,
});
},
},
// Return text for a specific license
// Return text for a specific license
licenseText
(
key
,
data
,
callback
)
{
licenseText
(
key
,
data
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
licensePath
)
const
url
=
Api
.
buildUrl
(
Api
.
licensePath
)
.
replace
(
'
:key
'
,
key
);
.
replace
(
'
:key
'
,
key
);
return
$
.
ajax
({
return
axios
.
get
(
url
,
{
url
,
params
:
data
,
data
,
})
})
.
done
(
license
=>
callback
(
license
));
.
then
(
res
=>
callback
(
res
.
data
));
},
},
gitignoreText
(
key
,
callback
)
{
gitignoreText
(
key
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
gitignorePath
)
const
url
=
Api
.
buildUrl
(
Api
.
gitignorePath
)
.
replace
(
'
:key
'
,
key
);
.
replace
(
'
:key
'
,
key
);
return
$
.
get
(
url
,
gitignore
=>
callback
(
gitignore
));
return
axios
.
get
(
url
)
.
then
(({
data
})
=>
callback
(
data
));
},
},
gitlabCiYml
(
key
,
callback
)
{
gitlabCiYml
(
key
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
gitlabCiYmlPath
)
const
url
=
Api
.
buildUrl
(
Api
.
gitlabCiYmlPath
)
.
replace
(
'
:key
'
,
key
);
.
replace
(
'
:key
'
,
key
);
return
$
.
get
(
url
,
file
=>
callback
(
file
));
return
axios
.
get
(
url
)
.
then
(({
data
})
=>
callback
(
data
));
},
},
dockerfileYml
(
key
,
callback
)
{
dockerfileYml
(
key
,
callback
)
{
const
url
=
Api
.
buildUrl
(
Api
.
dockerfilePath
).
replace
(
'
:key
'
,
key
);
const
url
=
Api
.
buildUrl
(
Api
.
dockerfilePath
).
replace
(
'
:key
'
,
key
);
$
.
get
(
url
,
callback
);
return
axios
.
get
(
url
)
.
then
(({
data
})
=>
callback
(
data
));
},
},
issueTemplate
(
namespacePath
,
projectPath
,
key
,
type
,
callback
)
{
issueTemplate
(
namespacePath
,
projectPath
,
key
,
type
,
callback
)
{
...
@@ -182,23 +163,18 @@ const Api = {
...
@@ -182,23 +163,18 @@ const Api = {
.
replace
(
'
:type
'
,
type
)
.
replace
(
'
:type
'
,
type
)
.
replace
(
'
:project_path
'
,
projectPath
)
.
replace
(
'
:project_path
'
,
projectPath
)
.
replace
(
'
:namespace_path
'
,
namespacePath
);
.
replace
(
'
:namespace_path
'
,
namespacePath
);
$
.
ajax
({
return
axios
.
get
(
url
)
url
,
.
then
(({
data
})
=>
callback
(
null
,
data
))
dataType
:
'
json
'
,
.
catch
(
callback
);
})
.
done
(
file
=>
callback
(
null
,
file
))
.
fail
(
callback
);
},
},
users
(
query
,
options
)
{
users
(
query
,
options
)
{
const
url
=
Api
.
buildUrl
(
this
.
usersPath
);
const
url
=
Api
.
buildUrl
(
this
.
usersPath
);
return
Api
.
wrapAjaxCall
({
return
axios
.
get
(
url
,
{
url
,
params
:
Object
.
assign
({
data
:
Object
.
assign
({
search
:
query
,
search
:
query
,
per_page
:
20
,
per_page
:
20
,
},
options
),
},
options
),
dataType
:
'
json
'
,
});
});
},
},
...
@@ -209,21 +185,6 @@ const Api = {
...
@@ -209,21 +185,6 @@ const Api = {
}
}
return
urlRoot
+
url
.
replace
(
'
:version
'
,
gon
.
api_version
);
return
urlRoot
+
url
.
replace
(
'
:version
'
,
gon
.
api_version
);
},
},
wrapAjaxCall
(
options
)
{
return
new
Promise
((
resolve
,
reject
)
=>
{
// jQuery 2 is not Promises/A+ compatible (missing catch)
$
.
ajax
(
options
)
// eslint-disable-line promise/catch-or-return
.
then
(
data
=>
resolve
(
data
),
(
jqXHR
,
textStatus
,
errorThrown
)
=>
{
const
error
=
new
Error
(
`
${
options
.
url
}
:
${
errorThrown
}
`
);
error
.
textStatus
=
textStatus
;
if
(
jqXHR
&&
jqXHR
.
responseJSON
)
error
.
responseJSON
=
jqXHR
.
responseJSON
;
reject
(
error
);
},
);
});
},
};
};
export
default
Api
;
export
default
Api
;
app/assets/javascripts/ide/stores/actions.js
View file @
9af1773f
...
@@ -90,7 +90,7 @@ export const commitChanges = (
...
@@ -90,7 +90,7 @@ export const commitChanges = (
)
=>
)
=>
service
service
.
commit
(
state
.
currentProjectId
,
payload
)
.
commit
(
state
.
currentProjectId
,
payload
)
.
then
((
data
)
=>
{
.
then
((
{
data
}
)
=>
{
const
{
branch
}
=
payload
;
const
{
branch
}
=
payload
;
if
(
!
data
.
short_id
)
{
if
(
!
data
.
short_id
)
{
flash
(
data
.
message
,
'
alert
'
,
document
,
null
,
false
,
true
);
flash
(
data
.
message
,
'
alert
'
,
document
,
null
,
false
,
true
);
...
@@ -147,8 +147,8 @@ export const commitChanges = (
...
@@ -147,8 +147,8 @@ export const commitChanges = (
})
})
.
catch
((
err
)
=>
{
.
catch
((
err
)
=>
{
let
errMsg
=
'
Error committing changes. Please try again.
'
;
let
errMsg
=
'
Error committing changes. Please try again.
'
;
if
(
err
.
response
JSON
&&
err
.
responseJSON
.
message
)
{
if
(
err
.
response
.
data
&&
err
.
response
.
data
.
message
)
{
errMsg
+=
` (
${
stripHtml
(
err
.
response
JSON
.
message
)}
)`
;
errMsg
+=
` (
${
stripHtml
(
err
.
response
.
data
.
message
)}
)`
;
}
}
flash
(
errMsg
,
'
alert
'
,
document
,
null
,
false
,
true
);
flash
(
errMsg
,
'
alert
'
,
document
,
null
,
false
,
true
);
window
.
dispatchEvent
(
new
Event
(
'
resize
'
));
window
.
dispatchEvent
(
new
Event
(
'
resize
'
));
...
...
app/assets/javascripts/ide/stores/actions/branch.js
View file @
9af1773f
...
@@ -10,7 +10,7 @@ export const getBranchData = (
...
@@ -10,7 +10,7 @@ export const getBranchData = (
!
state
.
projects
[
`
${
projectId
}
`
].
branches
[
branchId
])
!
state
.
projects
[
`
${
projectId
}
`
].
branches
[
branchId
])
||
force
)
{
||
force
)
{
service
.
getBranchData
(
`
${
projectId
}
`
,
branchId
)
service
.
getBranchData
(
`
${
projectId
}
`
,
branchId
)
.
then
((
data
)
=>
{
.
then
((
{
data
}
)
=>
{
const
{
id
}
=
data
.
commit
;
const
{
id
}
=
data
.
commit
;
commit
(
types
.
SET_BRANCH
,
{
projectPath
:
`
${
projectId
}
`
,
branchName
:
branchId
,
branch
:
data
});
commit
(
types
.
SET_BRANCH
,
{
projectPath
:
`
${
projectId
}
`
,
branchName
:
branchId
,
branch
:
data
});
commit
(
types
.
SET_BRANCH_WORKING_REFERENCE
,
{
projectId
,
branchId
,
reference
:
id
});
commit
(
types
.
SET_BRANCH_WORKING_REFERENCE
,
{
projectId
,
branchId
,
reference
:
id
});
...
...
app/assets/javascripts/lib/utils/users_cache.js
View file @
9af1773f
...
@@ -8,16 +8,16 @@ class UsersCache extends Cache {
...
@@ -8,16 +8,16 @@ class UsersCache extends Cache {
}
}
return
Api
.
users
(
''
,
{
username
})
return
Api
.
users
(
''
,
{
username
})
.
then
((
users
)
=>
{
.
then
((
{
data
}
)
=>
{
if
(
!
users
.
length
)
{
if
(
!
data
.
length
)
{
throw
new
Error
(
`User "
${
username
}
" could not be found!`
);
throw
new
Error
(
`User "
${
username
}
" could not be found!`
);
}
}
if
(
users
.
length
>
1
)
{
if
(
data
.
length
>
1
)
{
throw
new
Error
(
`Expected username "
${
username
}
" to be unique!`
);
throw
new
Error
(
`Expected username "
${
username
}
" to be unique!`
);
}
}
const
user
=
users
[
0
];
const
user
=
data
[
0
];
this
.
internalStorage
[
username
]
=
user
;
this
.
internalStorage
[
username
]
=
user
;
return
user
;
return
user
;
});
});
...
...
spec/javascripts/api_spec.js
View file @
9af1773f
import
MockAdapter
from
'
axios-mock-adapter
'
;
import
axios
from
'
~/lib/utils/axios_utils
'
;
import
Api
from
'
~/api
'
;
import
Api
from
'
~/api
'
;
describe
(
'
Api
'
,
()
=>
{
describe
(
'
Api
'
,
()
=>
{
...
@@ -7,20 +9,17 @@ describe('Api', () => {
...
@@ -7,20 +9,17 @@ describe('Api', () => {
api_version
:
dummyApiVersion
,
api_version
:
dummyApiVersion
,
relative_url_root
:
dummyUrlRoot
,
relative_url_root
:
dummyUrlRoot
,
};
};
const
dummyResponse
=
'
hello from outer space!
'
;
const
sendDummyResponse
=
()
=>
{
const
deferred
=
$
.
Deferred
();
deferred
.
resolve
(
dummyResponse
);
return
deferred
.
promise
();
};
let
originalGon
;
let
originalGon
;
let
mock
;
beforeEach
(()
=>
{
beforeEach
(()
=>
{
mock
=
new
MockAdapter
(
axios
);
originalGon
=
window
.
gon
;
originalGon
=
window
.
gon
;
window
.
gon
=
Object
.
assign
({},
dummyGon
);
window
.
gon
=
Object
.
assign
({},
dummyGon
);
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
mock
.
restore
();
window
.
gon
=
originalGon
;
window
.
gon
=
originalGon
;
});
});
...
@@ -39,14 +38,12 @@ describe('Api', () => {
...
@@ -39,14 +38,12 @@ describe('Api', () => {
it
(
'
fetches a group
'
,
(
done
)
=>
{
it
(
'
fetches a group
'
,
(
done
)
=>
{
const
groupId
=
'
123456
'
;
const
groupId
=
'
123456
'
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/groups/
${
groupId
}
.json`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/groups/
${
groupId
}
.json`
;
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
{
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
name
:
'
test
'
,
expect
(
request
.
dataType
).
toEqual
(
'
json
'
);
return
sendDummyResponse
();
});
});
Api
.
group
(
groupId
,
(
response
)
=>
{
Api
.
group
(
groupId
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
.
name
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -57,19 +54,13 @@ describe('Api', () => {
...
@@ -57,19 +54,13 @@ describe('Api', () => {
const
query
=
'
dummy query
'
;
const
query
=
'
dummy query
'
;
const
options
=
{
unused
:
'
option
'
};
const
options
=
{
unused
:
'
option
'
};
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/groups.json`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/groups.json`
;
const
expectedData
=
Object
.
assign
({
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
[{
search
:
query
,
name
:
'
test
'
,
per_page
:
20
,
}]);
},
options
);
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
expect
(
request
.
dataType
).
toEqual
(
'
json
'
);
expect
(
request
.
data
).
toEqual
(
expectedData
);
return
sendDummyResponse
();
});
Api
.
groups
(
query
,
options
,
(
response
)
=>
{
Api
.
groups
(
query
,
options
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
.
length
).
toBe
(
1
);
expect
(
response
[
0
].
name
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -79,19 +70,13 @@ describe('Api', () => {
...
@@ -79,19 +70,13 @@ describe('Api', () => {
it
(
'
fetches namespaces
'
,
(
done
)
=>
{
it
(
'
fetches namespaces
'
,
(
done
)
=>
{
const
query
=
'
dummy query
'
;
const
query
=
'
dummy query
'
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/namespaces.json`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/namespaces.json`
;
const
expectedData
=
{
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
[{
search
:
query
,
name
:
'
test
'
,
per_page
:
20
,
}]);
};
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
expect
(
request
.
dataType
).
toEqual
(
'
json
'
);
expect
(
request
.
data
).
toEqual
(
expectedData
);
return
sendDummyResponse
();
});
Api
.
namespaces
(
query
,
(
response
)
=>
{
Api
.
namespaces
(
query
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
.
length
).
toBe
(
1
);
expect
(
response
[
0
].
name
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -103,21 +88,13 @@ describe('Api', () => {
...
@@ -103,21 +88,13 @@ describe('Api', () => {
const
options
=
{
unused
:
'
option
'
};
const
options
=
{
unused
:
'
option
'
};
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/projects.json`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/projects.json`
;
window
.
gon
.
current_user_id
=
1
;
window
.
gon
.
current_user_id
=
1
;
const
expectedData
=
Object
.
assign
({
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
[{
search
:
query
,
name
:
'
test
'
,
per_page
:
20
,
}]);
membership
:
true
,
simple
:
true
,
},
options
);
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
expect
(
request
.
dataType
).
toEqual
(
'
json
'
);
expect
(
request
.
data
).
toEqual
(
expectedData
);
return
sendDummyResponse
();
});
Api
.
projects
(
query
,
options
,
(
response
)
=>
{
Api
.
projects
(
query
,
options
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
.
length
).
toBe
(
1
);
expect
(
response
[
0
].
name
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -126,20 +103,13 @@ describe('Api', () => {
...
@@ -126,20 +103,13 @@ describe('Api', () => {
const
query
=
'
dummy query
'
;
const
query
=
'
dummy query
'
;
const
options
=
{
unused
:
'
option
'
};
const
options
=
{
unused
:
'
option
'
};
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/projects.json`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/projects.json`
;
const
expectedData
=
Object
.
assign
({
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
[{
search
:
query
,
name
:
'
test
'
,
per_page
:
20
,
}]);
simple
:
true
,
},
options
);
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
expect
(
request
.
dataType
).
toEqual
(
'
json
'
);
expect
(
request
.
data
).
toEqual
(
expectedData
);
return
sendDummyResponse
();
});
Api
.
projects
(
query
,
options
,
(
response
)
=>
{
Api
.
projects
(
query
,
options
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
.
length
).
toBe
(
1
);
expect
(
response
[
0
].
name
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -154,16 +124,16 @@ describe('Api', () => {
...
@@ -154,16 +124,16 @@ describe('Api', () => {
const
expectedData
=
{
const
expectedData
=
{
label
:
labelData
,
label
:
labelData
,
};
};
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
mock
.
onPost
(
expectedUrl
).
reply
((
config
)
=>
{
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
expect
(
config
.
data
).
toBe
(
JSON
.
stringify
(
expectedData
)
);
expect
(
request
.
dataType
).
toEqual
(
'
json
'
);
expect
(
request
.
type
).
toEqual
(
'
POST
'
);
return
[
200
,
{
expect
(
request
.
data
).
toEqual
(
expectedData
);
name
:
'
test
'
,
return
sendDummyResponse
()
;
}]
;
});
});
Api
.
newLabel
(
namespace
,
project
,
labelData
,
(
response
)
=>
{
Api
.
newLabel
(
namespace
,
project
,
labelData
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
.
name
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -174,19 +144,13 @@ describe('Api', () => {
...
@@ -174,19 +144,13 @@ describe('Api', () => {
const
groupId
=
'
123456
'
;
const
groupId
=
'
123456
'
;
const
query
=
'
dummy query
'
;
const
query
=
'
dummy query
'
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/groups/
${
groupId
}
/projects.json`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/groups/
${
groupId
}
/projects.json`
;
const
expectedData
=
{
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
[{
search
:
query
,
name
:
'
test
'
,
per_page
:
20
,
}]);
};
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
expect
(
request
.
dataType
).
toEqual
(
'
json
'
);
expect
(
request
.
data
).
toEqual
(
expectedData
);
return
sendDummyResponse
();
});
Api
.
groupProjects
(
groupId
,
query
,
(
response
)
=>
{
Api
.
groupProjects
(
groupId
,
query
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
.
length
).
toBe
(
1
);
expect
(
response
[
0
].
name
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -197,14 +161,10 @@ describe('Api', () => {
...
@@ -197,14 +161,10 @@ describe('Api', () => {
const
licenseKey
=
"
driver's license
"
;
const
licenseKey
=
"
driver's license
"
;
const
data
=
{
unused
:
'
option
'
};
const
data
=
{
unused
:
'
option
'
};
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/templates/licenses/
${
licenseKey
}
`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/templates/licenses/
${
licenseKey
}
`
;
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
'
test
'
);
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
expect
(
request
.
data
).
toEqual
(
data
);
return
sendDummyResponse
();
});
Api
.
licenseText
(
licenseKey
,
data
,
(
response
)
=>
{
Api
.
licenseText
(
licenseKey
,
data
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -214,13 +174,10 @@ describe('Api', () => {
...
@@ -214,13 +174,10 @@ describe('Api', () => {
it
(
'
fetches a gitignore text
'
,
(
done
)
=>
{
it
(
'
fetches a gitignore text
'
,
(
done
)
=>
{
const
gitignoreKey
=
'
ignore git
'
;
const
gitignoreKey
=
'
ignore git
'
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/templates/gitignores/
${
gitignoreKey
}
`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/templates/gitignores/
${
gitignoreKey
}
`
;
spyOn
(
jQuery
,
'
get
'
).
and
.
callFake
((
url
,
callback
)
=>
{
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
'
test
'
);
expect
(
url
).
toEqual
(
expectedUrl
);
callback
(
dummyResponse
);
});
Api
.
gitignoreText
(
gitignoreKey
,
(
response
)
=>
{
Api
.
gitignoreText
(
gitignoreKey
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -230,13 +187,10 @@ describe('Api', () => {
...
@@ -230,13 +187,10 @@ describe('Api', () => {
it
(
'
fetches a .gitlab-ci.yml
'
,
(
done
)
=>
{
it
(
'
fetches a .gitlab-ci.yml
'
,
(
done
)
=>
{
const
gitlabCiYmlKey
=
'
Y CI ML
'
;
const
gitlabCiYmlKey
=
'
Y CI ML
'
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/templates/gitlab_ci_ymls/
${
gitlabCiYmlKey
}
`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/templates/gitlab_ci_ymls/
${
gitlabCiYmlKey
}
`
;
spyOn
(
jQuery
,
'
get
'
).
and
.
callFake
((
url
,
callback
)
=>
{
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
'
test
'
);
expect
(
url
).
toEqual
(
expectedUrl
);
callback
(
dummyResponse
);
});
Api
.
gitlabCiYml
(
gitlabCiYmlKey
,
(
response
)
=>
{
Api
.
gitlabCiYml
(
gitlabCiYmlKey
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -246,13 +200,10 @@ describe('Api', () => {
...
@@ -246,13 +200,10 @@ describe('Api', () => {
it
(
'
fetches a Dockerfile
'
,
(
done
)
=>
{
it
(
'
fetches a Dockerfile
'
,
(
done
)
=>
{
const
dockerfileYmlKey
=
'
a giant whale
'
;
const
dockerfileYmlKey
=
'
a giant whale
'
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/templates/dockerfiles/
${
dockerfileYmlKey
}
`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/templates/dockerfiles/
${
dockerfileYmlKey
}
`
;
spyOn
(
jQuery
,
'
get
'
).
and
.
callFake
((
url
,
callback
)
=>
{
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
'
test
'
);
expect
(
url
).
toEqual
(
expectedUrl
);
callback
(
dummyResponse
);
});
Api
.
dockerfileYml
(
dockerfileYmlKey
,
(
response
)
=>
{
Api
.
dockerfileYml
(
dockerfileYmlKey
,
(
response
)
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
response
).
toBe
(
'
test
'
);
done
();
done
();
});
});
});
});
...
@@ -265,14 +216,10 @@ describe('Api', () => {
...
@@ -265,14 +216,10 @@ describe('Api', () => {
const
templateKey
=
'
template #%?.key
'
;
const
templateKey
=
'
template #%?.key
'
;
const
templateType
=
'
template type
'
;
const
templateType
=
'
template type
'
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/
${
namespace
}
/
${
project
}
/templates/
${
templateType
}
/
${
encodeURIComponent
(
templateKey
)}
`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/
${
namespace
}
/
${
project
}
/templates/
${
templateType
}
/
${
encodeURIComponent
(
templateKey
)}
`
;
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
'
test
'
);
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
return
sendDummyResponse
();
});
Api
.
issueTemplate
(
namespace
,
project
,
templateKey
,
templateType
,
(
error
,
response
)
=>
{
Api
.
issueTemplate
(
namespace
,
project
,
templateKey
,
templateType
,
(
error
,
response
)
=>
{
expect
(
error
).
toBe
(
null
);
expect
(
response
).
toBe
(
'
test
'
);
expect
(
response
).
toBe
(
dummyResponse
);
done
();
done
();
});
});
});
});
...
@@ -283,20 +230,14 @@ describe('Api', () => {
...
@@ -283,20 +230,14 @@ describe('Api', () => {
const
query
=
'
dummy query
'
;
const
query
=
'
dummy query
'
;
const
options
=
{
unused
:
'
option
'
};
const
options
=
{
unused
:
'
option
'
};
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/users.json`
;
const
expectedUrl
=
`
${
dummyUrlRoot
}
/api/
${
dummyApiVersion
}
/users.json`
;
const
expectedData
=
Object
.
assign
({
mock
.
onGet
(
expectedUrl
).
reply
(
200
,
[{
search
:
query
,
name
:
'
test
'
,
per_page
:
20
,
}]);
},
options
);
spyOn
(
jQuery
,
'
ajax
'
).
and
.
callFake
((
request
)
=>
{
expect
(
request
.
url
).
toEqual
(
expectedUrl
);
expect
(
request
.
dataType
).
toEqual
(
'
json
'
);
expect
(
request
.
data
).
toEqual
(
expectedData
);
return
sendDummyResponse
();
});
Api
.
users
(
query
,
options
)
Api
.
users
(
query
,
options
)
.
then
((
response
)
=>
{
.
then
(({
data
})
=>
{
expect
(
response
).
toBe
(
dummyResponse
);
expect
(
data
.
length
).
toBe
(
1
);
expect
(
data
[
0
].
name
).
toBe
(
'
test
'
);
})
})
.
then
(
done
)
.
then
(
done
)
.
catch
(
done
.
fail
);
.
catch
(
done
.
fail
);
...
...
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