Fixed bug where numbers where returned as string

This commit is contained in:
Lukas Metzger 2018-03-24 15:09:33 +01:00
parent 5928203a0a
commit 6ec9c81c32
4 changed files with 241 additions and 229 deletions

View file

@ -103,6 +103,8 @@ class Domains
if ($item['type'] != 'SLAVE') {
unset($item['master']);
}
$item['id'] = intval($item['id']);
$item['records'] = intval($item['records']);
return $item;
}, $data);
}
@ -147,6 +149,7 @@ class Domains
$query->execute();
$record = $query->fetch();
$record['id'] = intval($record['id']);
if ($type !== 'SLAVE') {
unset($record['master']);
}

View file

@ -1,100 +1,105 @@
const cartesianProduct = require('cartesian-product');
require('../testlib')('admin', async function (assert, req) {
//Test missing fields
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'abc.de'
}
});
(async function () {
await require('../testlib')('admin', async function (assert, req) {
//Test missing fields
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'abc.de'
}
});
assert.equal(res.status, 422, 'Missing type filed should trigger error.');
assert.equal(res.status, 422, 'Missing type filed should trigger error.');
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'abc.de',
type: 'SLAVE'
}
});
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'abc.de',
type: 'SLAVE'
}
});
assert.equal(res.status, 422, 'Missing master field for SLAVE domain should trigger error.');
assert.equal(res.status, 422, 'Missing master field for SLAVE domain should trigger error.');
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'foo.de',
type: 'MASTER'
}
});
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'foo.de',
type: 'MASTER'
}
});
assert.equal(res.status, 409, 'Existing domain should trigger error.');
assert.equal(res.status, 409, 'Existing domain should trigger error.');
//Test creation of master zone
var res = await req({
url: '/domains',
method: 'post',
data: {
//Test creation of master zone
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'master.de',
type: 'MASTER'
}
});
assert.equal(res.status, 201, 'Creation should be successfull');
assert.equal(res.data, {
id: 6,
name: 'master.de',
type: 'MASTER'
}
});
}, 'Creation result fail.')
assert.equal(res.status, 201, 'Creation should be successfull');
assert.equal(res.data, {
id: '6',
name: 'master.de',
type: 'MASTER'
}, 'Creation result fail.')
//Test creation of native zone
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'native.de',
type: 'NATIVE'
}
});
//Test creation of native zone
var res = await req({
url: '/domains',
method: 'post',
data: {
assert.equal(res.status, 201, 'Creation should be successfull');
assert.equal(res.data, {
id: 7,
name: 'native.de',
type: 'NATIVE'
}
});
}, 'Creation result fail.')
assert.equal(res.status, 201, 'Creation should be successfull');
assert.equal(res.data, {
id: '7',
name: 'native.de',
type: 'NATIVE'
}, 'Creation result fail.')
//Test creation of slave zone
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'slave.de',
type: 'SLAVE',
master: '1.2.3.4'
}
});
//Test creation of slave zone
var res = await req({
url: '/domains',
method: 'post',
data: {
assert.equal(res.status, 201, 'Creation should be successfull');
assert.equal(res.data, {
id: 8,
name: 'slave.de',
type: 'SLAVE'
}
type: 'SLAVE',
master: '1.2.3.4'
}, 'Creation result fail.')
});
assert.equal(res.status, 201, 'Creation should be successfull');
assert.equal(res.data, {
id: '8',
name: 'slave.de',
type: 'SLAVE'
}, 'Creation result fail.')
});
await require('../testlib')('user', async function (assert, req) {
//Test insufficient privileges
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'foo.de'
}
});
require('../testlib')('user', async function (assert, req) {
//Test insufficient privileges
var res = await req({
url: '/domains',
method: 'post',
data: {
name: 'foo.de'
}
assert.equal(res.status, 403, 'Domain creation should be forbidden for users.')
});
assert.equal(res.status, 403, 'Domain creation should be forbidden for users.')
});
})();

View file

@ -1,106 +1,108 @@
const cartesianProduct = require('cartesian-product');
require('../testlib')('admin', async function (assert, req) {
//GET /domains?page=5&pagesize=10&query=foo&sort=id-asc,name-desc,type-asc,records-asc&type=MASTER
(async function () {
require('../testlib')('admin', async function (assert, req) {
//GET /domains?page=5&pagesize=10&query=foo&sort=id-asc,name-desc,type-asc,records-asc&type=MASTER
//Test sorting in all combinations
const sortCombinations = cartesianProduct([
['', 'id-asc', 'id-desc'],
['', 'name-asc', 'name-desc'],
['', 'type-asc', 'type-desc'],
['', 'records-asc', 'records-desc']
]);
//Test sorting in all combinations
const sortCombinations = cartesianProduct([
['', 'id-asc', 'id-desc'],
['', 'name-asc', 'name-desc'],
['', 'type-asc', 'type-desc'],
['', 'records-asc', 'records-desc']
]);
for (list of sortCombinations) {
list = list.filter((str) => str.length > 0);
var sortQuery = list.join(',');
for (list of sortCombinations) {
list = list.filter((str) => str.length > 0);
var sortQuery = list.join(',');
var res = await req({
url: '/domains?sort=' + sortQuery,
method: 'get'
});
assert.equal(res.status, 200);
var sortedData = res.data.results.slice();
sortedData.sort(function (a, b) {
for (sort of list) {
var spec = sort.split('-');
if (a[spec[0]] < b[spec[0]]) {
return spec[1] == 'asc' ? -1 : 1;
} else if (a[spec[0]] > b[spec[0]]) {
return spec[1] == 'asc' ? 1 : -1;
}
}
return 0;
});
assert.equal(res.data.results, sortedData, 'Sort failed for ' + res.config.url);
}
//Test paging
var res = await req({
url: '/domains?sort=' + sortQuery,
url: '/domains?pagesize=3',
method: 'get'
});
assert.equal(res.status, 200);
assert.equal(res.status, 200, 'Status should be OK');
assert.equal(res.data.paging, {
page: 1,
total: 2,
pagesize: 3
}, 'Paging data fail for ' + res.config.url);
assert.equal(res.data.results.length, 3, "Should be 3 results.");
var sortedData = res.data.results.slice();
sortedData.sort(function (a, b) {
for (sort of list) {
var spec = sort.split('-');
if (a[spec[0]] < b[spec[0]]) {
return spec[1] == 'asc' ? -1 : 1;
} else if (a[spec[0]] > b[spec[0]]) {
return spec[1] == 'asc' ? 1 : -1;
}
}
return 0;
var res = await req({
url: '/domains?pagesize=3&page=2',
method: 'get'
});
assert.equal(res.data.results, sortedData, 'Sort failed for ' + res.config.url);
}
assert.equal(res.status, 200, 'Status should be OK');
assert.equal(res.data.paging, {
page: 2,
total: 2,
pagesize: 3
}, 'Paging data fail for ' + res.config.url);
assert.equal(res.data.results.length, 2, "Should be 2 results.");
//Test paging
var res = await req({
url: '/domains?pagesize=3',
method: 'get'
//Test query
var res = await req({
url: '/domains?query=.net&sort=id-asc',
method: 'get'
});
assert.equal(res.status, 200, 'Status should be OK');
assert.equal(res.data.results, [
{
id: 2,
name: 'slave.example.net',
type: 'SLAVE',
master: '12.34.56.78',
records: 0
},
{
id: 4,
name: 'bar.net',
type: 'MASTER',
records: 0
}
], 'Result fail for ' + res.config.url);
//Type filter
var res = await req({
url: '/domains?type=NATIVE',
method: 'get'
});
assert.equal(res.status, 200, 'Status should be OK');
assert.equal(res.data.results, [
{
id: 3,
name: 'foo.de',
type: 'NATIVE',
records: 0
}
], 'Result fail for ' + res.config.url);
});
assert.equal(res.status, 200, 'Status should be OK');
assert.equal(res.data.paging, {
page: 1,
total: 2,
pagesize: 3
}, 'Paging data fail for ' + res.config.url);
assert.equal(res.data.results.length, 3, "Should be 3 results.");
var res = await req({
url: '/domains?pagesize=3&page=2',
method: 'get'
});
assert.equal(res.status, 200, 'Status should be OK');
assert.equal(res.data.paging, {
page: 2,
total: 2,
pagesize: 3
}, 'Paging data fail for ' + res.config.url);
assert.equal(res.data.results.length, 2, "Should be 2 results.");
//Test query
var res = await req({
url: '/domains?query=.net&sort=id-asc',
method: 'get'
});
assert.equal(res.status, 200, 'Status should be OK');
assert.equal(res.data.results, [
{
id: '2',
name: 'slave.example.net',
type: 'SLAVE',
master: '12.34.56.78',
records: '0'
},
{
id: '4',
name: 'bar.net',
type: 'MASTER',
records: '0'
}
], 'Result fail for ' + res.config.url);
//Type filter
var res = await req({
url: '/domains?type=NATIVE',
method: 'get'
});
assert.equal(res.status, 200, 'Status should be OK');
assert.equal(res.data.results, [
{
id: '3',
name: 'foo.de',
type: 'NATIVE',
records: '0'
}
], 'Result fail for ' + res.config.url);
});
})();

View file

@ -1,61 +1,63 @@
require('../testlib')('admin', async function (assert, req) {
//Try to login with invalid username and password
var res = await req({
url: '/sessions',
method: 'post',
data: {
username: 'foo',
password: 'bar'
}
(async function () {
require('../testlib')('admin', async function (assert, req) {
//Try to login with invalid username and password
var res = await req({
url: '/sessions',
method: 'post',
data: {
username: 'foo',
password: 'bar'
}
});
assert.equal(res.status, 403, 'Status not valid');
//Try to login with invalid username
var res = await req({
url: '/sessions',
method: 'post',
data: {
username: 'foo',
password: 'admin'
}
});
assert.equal(res.status, 403, 'Status not valid');
//Try to login with invalid password
var res = await req({
url: '/sessions',
method: 'post',
data: {
username: 'admin',
password: 'foo'
}
});
assert.equal(res.status, 403, 'Status not valid');
//Try to login with missing field
var res = await req({
url: '/sessions',
method: 'post',
data: {
password: 'admin'
}
});
assert.equal(res.status, 422, 'Status not valid');
//Try to login with invalid username and password
var res = await req({
url: '/sessions',
method: 'post',
data: {
username: 'foo/admin',
password: 'admin'
}
});
assert.equal(res.status, 201, 'Status not valid');
});
assert.equal(res.status, 403, 'Status not valid');
//Try to login with invalid username
var res = await req({
url: '/sessions',
method: 'post',
data: {
username: 'foo',
password: 'admin'
}
});
assert.equal(res.status, 403, 'Status not valid');
//Try to login with invalid password
var res = await req({
url: '/sessions',
method: 'post',
data: {
username: 'admin',
password: 'foo'
}
});
assert.equal(res.status, 403, 'Status not valid');
//Try to login with missing field
var res = await req({
url: '/sessions',
method: 'post',
data: {
password: 'admin'
}
});
assert.equal(res.status, 422, 'Status not valid');
//Try to login with invalid username and password
var res = await req({
url: '/sessions',
method: 'post',
data: {
username: 'foo/admin',
password: 'admin'
}
});
assert.equal(res.status, 201, 'Status not valid');
});
})();