]> gerrit.simantics Code Review - simantics/district.git/blob - org.simantics.maps.server/node/node-v4.8.0-win-x64/node_modules/npm/node_modules/npm-registry-client/test/dist-tags-update.js
Adding integrated tile server
[simantics/district.git] / org.simantics.maps.server / node / node-v4.8.0-win-x64 / node_modules / npm / node_modules / npm-registry-client / test / dist-tags-update.js
1 var test = require('tap').test
2
3 var server = require('./lib/server.js')
4 var common = require('./lib/common.js')
5 var client = common.freshClient()
6
7 function nop () {}
8
9 var BASE_URL = 'http://localhost:1337/'
10 var URI = '/-/package/underscore/dist-tags'
11 var TOKEN = 'foo'
12 var AUTH = {
13   token: TOKEN
14 }
15 var PACKAGE = 'underscore'
16 var DIST_TAGS = {
17   'a': '8.0.8',
18   'b': '3.0.3'
19 }
20 var PARAMS = {
21   'package': PACKAGE,
22   distTags: DIST_TAGS,
23   auth: AUTH
24 }
25
26 test('distTags.update call contract', function (t) {
27   t.throws(function () {
28     client.distTags.update(undefined, AUTH, nop)
29   }, 'requires a URI')
30
31   t.throws(function () {
32     client.distTags.update([], PARAMS, nop)
33   }, 'requires URI to be a string')
34
35   t.throws(function () {
36     client.distTags.update(BASE_URL, undefined, nop)
37   }, 'requires params object')
38
39   t.throws(function () {
40     client.distTags.update(BASE_URL, '', nop)
41   }, 'params must be object')
42
43   t.throws(function () {
44     client.distTags.update(BASE_URL, PARAMS, undefined)
45   }, 'requires callback')
46
47   t.throws(function () {
48     client.distTags.update(BASE_URL, PARAMS, 'callback')
49   }, 'callback must be function')
50
51   t.throws(
52     function () {
53       var params = { distTags: DIST_TAGS, auth: AUTH }
54       client.distTags.update(BASE_URL, params, nop)
55     },
56     {
57       name: 'AssertionError',
58       message: 'must pass package name to distTags.update'
59     },
60     'distTags.update must include package name'
61   )
62
63   t.throws(
64     function () {
65       var params = { 'package': PACKAGE, auth: AUTH }
66       client.distTags.update(BASE_URL, params, nop)
67     },
68     {
69       name: 'AssertionError',
70       message: 'must pass distTags map to distTags.update'
71     },
72     'distTags.update must include dist-tags'
73   )
74
75   t.throws(
76     function () {
77       var params = { 'package': PACKAGE, distTags: DIST_TAGS }
78       client.distTags.update(BASE_URL, params, nop)
79     },
80     { name: 'AssertionError', message: 'must pass auth to distTags.update' },
81     'distTags.update must include auth'
82   )
83
84   t.end()
85 })
86
87 test('update dist-tags for a package', function (t) {
88   server.expect('POST', URI, function (req, res) {
89     t.equal(req.method, 'POST')
90
91     var b = ''
92     req.setEncoding('utf8')
93     req.on('data', function (d) {
94       b += d
95     })
96
97     req.on('end', function () {
98       var d = JSON.parse(b)
99       t.deepEqual(d, DIST_TAGS, 'got back tags')
100
101       res.statusCode = 200
102       res.json(DIST_TAGS)
103     })
104   })
105
106   client.distTags.update(BASE_URL, PARAMS, function (error, data) {
107     t.ifError(error, 'no errors')
108     t.ok(data.a && data.b, 'dist-tags set')
109
110     server.close()
111     t.end()
112   })
113 })