mirror of
https://github.com/bigchaindb/js-bigchaindb-driver.git
synced 2025-01-03 18:35:13 +01:00
Adjust HTTP API endpoints and test
This commit is contained in:
parent
8cde6df907
commit
af49ec1c7a
@ -9,15 +9,15 @@ export default class Connection {
|
|||||||
|
|
||||||
getApiUrls(endpoints) {
|
getApiUrls(endpoints) {
|
||||||
// TODO: Use camel case
|
// TODO: Use camel case
|
||||||
return {
|
return this.path + {
|
||||||
'blocks': `${this.path}blocks`,
|
'blocks': 'blocks',
|
||||||
'blocks_detail': `${this.path}blocks/%(blockId)s`,
|
'blocks_detail': 'blocks/%(blockId)s',
|
||||||
'outputs': `${this.path}outputs`,
|
'outputs': 'outputs',
|
||||||
'statuses': `${this.path}statuses`,
|
'statuses': 'statuses',
|
||||||
'transactions': `${this.path}transactions`,
|
'transactions': 'transactions',
|
||||||
'transactions_detail': `${this.path}transactions/%(txId)s`,
|
'transactions_detail': 'transactions/%(transactionId)s',
|
||||||
'search_assets': `${this.path}assets`,
|
'search_assets': 'assets',
|
||||||
'votes': `${this.path}votes`
|
'votes': 'votes'
|
||||||
}[endpoints]
|
}[endpoints]
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -41,37 +41,37 @@ export default class Connection {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @public
|
* @public
|
||||||
* @param tx_id
|
* @param transactionId
|
||||||
*/
|
*/
|
||||||
getStatus(tx_id) { // eslint-disable-line camelcase
|
getStatus(transactionId) {
|
||||||
return this._req(this.getApiUrls('statuses'), {
|
return this._req(this.getApiUrls('statuses'), {
|
||||||
query: {
|
query: {
|
||||||
tx_id
|
transaction_id: transactionId
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @public
|
* @public
|
||||||
* @param txId
|
* @param transactionId
|
||||||
*/
|
*/
|
||||||
getTransaction(txId) {
|
getTransaction(transactionId) {
|
||||||
return this._req(this.getApiUrls('transactions_detail'), {
|
return this._req(this.getApiUrls('transactions_detail'), {
|
||||||
urlTemplateSpec: {
|
urlTemplateSpec: {
|
||||||
txId
|
transaction_id: transactionId
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @public
|
* @public
|
||||||
* @param tx_id
|
* @param transactionId
|
||||||
* @param status
|
* @param status
|
||||||
*/
|
*/
|
||||||
listBlocks({ tx_id, status }) {
|
listBlocks({ transactionId, status }) {
|
||||||
return this._req(this.getApiUrls('blocks'), {
|
return this._req(this.getApiUrls('blocks'), {
|
||||||
query: {
|
query: {
|
||||||
tx_id,
|
transaction_id: transactionId,
|
||||||
status
|
status
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@ -83,6 +83,7 @@ export default class Connection {
|
|||||||
* @param unspent
|
* @param unspent
|
||||||
* @param onlyJsonResponse
|
* @param onlyJsonResponse
|
||||||
*/
|
*/
|
||||||
|
// TODO: Use camel case for parameters
|
||||||
listOutputs({ public_key, unspent }, onlyJsonResponse = true) {
|
listOutputs({ public_key, unspent }, onlyJsonResponse = true) {
|
||||||
return this._req(this.getApiUrls('outputs'), {
|
return this._req(this.getApiUrls('outputs'), {
|
||||||
query: {
|
query: {
|
||||||
@ -97,6 +98,7 @@ export default class Connection {
|
|||||||
* @param asset_id
|
* @param asset_id
|
||||||
* @param operation
|
* @param operation
|
||||||
*/
|
*/
|
||||||
|
// TODO: Use camel case for parameters
|
||||||
listTransactions({ asset_id, operation }) {
|
listTransactions({ asset_id, operation }) {
|
||||||
return this._req(this.getApiUrls('transactions'), {
|
return this._req(this.getApiUrls('transactions'), {
|
||||||
query: {
|
query: {
|
||||||
@ -108,12 +110,12 @@ export default class Connection {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @public
|
* @public
|
||||||
* @param block_id
|
* @param blockId
|
||||||
*/
|
*/
|
||||||
listVotes(block_id) { // eslint-disable-line camelcase
|
listVotes(blockId) {
|
||||||
return this._req(this.getApiUrls('votes'), {
|
return this._req(this.getApiUrls('votes'), {
|
||||||
query: {
|
query: {
|
||||||
block_id
|
block_id: blockId
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
90
test/connection/test_connection.js
Normal file
90
test/connection/test_connection.js
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
import test from 'ava'
|
||||||
|
import sinon from 'sinon'
|
||||||
|
import { Connection } from '../../src'
|
||||||
|
|
||||||
|
const API_PATH = 'http://localhost:9984/api/v1/'
|
||||||
|
const conn = new Connection(API_PATH)
|
||||||
|
|
||||||
|
|
||||||
|
test('generate API URLS', t => {
|
||||||
|
const endpoints = {
|
||||||
|
'blocks': 'blocks',
|
||||||
|
'blocks_detail': 'blocks/%(blockId)s',
|
||||||
|
'outputs': 'outputs',
|
||||||
|
'statuses': 'statuses',
|
||||||
|
'transactions': 'transactions',
|
||||||
|
'transactions_detail': 'transactions/%(transactionId)s',
|
||||||
|
'search_assets': 'assets',
|
||||||
|
}
|
||||||
|
Object.keys(endpoints).forEach((endpointName) => {
|
||||||
|
const url = conn.getApiUrls(endpointName)
|
||||||
|
const expected = API_PATH + endpoints[endpointName]
|
||||||
|
t.is(url, expected)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
test('Get status for a transaction', t => {
|
||||||
|
const expectedPath = 'path'
|
||||||
|
const transactionId = 'abc'
|
||||||
|
|
||||||
|
conn._req = sinon.spy()
|
||||||
|
conn.getApiUrls = sinon.stub().returns(expectedPath)
|
||||||
|
|
||||||
|
conn.getStatus(transactionId)
|
||||||
|
t.truthy(conn._req.calledWith(
|
||||||
|
expectedPath,
|
||||||
|
{ query: { transaction_id: transactionId } }
|
||||||
|
))
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
test('Get transaction for a transaction id', t => {
|
||||||
|
const expectedPath = 'path'
|
||||||
|
const transactionId = 'abc'
|
||||||
|
|
||||||
|
conn._req = sinon.spy()
|
||||||
|
conn.getApiUrls = sinon.stub().returns(expectedPath)
|
||||||
|
|
||||||
|
conn.getTransaction(transactionId)
|
||||||
|
t.truthy(conn._req.calledWith(
|
||||||
|
expectedPath,
|
||||||
|
{ urlTemplateSpec: { transaction_id: transactionId } }
|
||||||
|
))
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
test('Get list of blocks for a transaction id', t => {
|
||||||
|
const expectedPath = 'path'
|
||||||
|
const transactionId = 'abc'
|
||||||
|
const status = 'status'
|
||||||
|
|
||||||
|
conn._req = sinon.spy()
|
||||||
|
conn.getApiUrls = sinon.stub().returns(expectedPath)
|
||||||
|
|
||||||
|
conn.listBlocks({ transactionId, status })
|
||||||
|
t.truthy(conn._req.calledWith(
|
||||||
|
expectedPath,
|
||||||
|
{
|
||||||
|
query: {
|
||||||
|
transaction_id: transactionId,
|
||||||
|
status
|
||||||
|
}
|
||||||
|
}
|
||||||
|
))
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
test('Get votes for a block id', t => {
|
||||||
|
const expectedPath = 'path'
|
||||||
|
const blockId = 'abc'
|
||||||
|
|
||||||
|
conn._req = sinon.spy()
|
||||||
|
conn.getApiUrls = sinon.stub().returns(expectedPath)
|
||||||
|
|
||||||
|
conn.listVotes(blockId)
|
||||||
|
t.truthy(conn._req.calledWith(
|
||||||
|
expectedPath,
|
||||||
|
{ query: { block_id: blockId } }
|
||||||
|
))
|
||||||
|
})
|
Loading…
Reference in New Issue
Block a user