mirror of
https://github.com/bigchaindb/bigchaindb.git
synced 2024-10-13 13:34:05 +00:00

* Problem: core.py contains an unused class, `Bigchain` Solution: Remove core.py. Refactor BigchainDB Class to remove inheritance from Bigchain. * Problem: core.py contains an unused class, `Bigchain` Solution: Remove core.py. Refactor BigchainDB Class to remove inheritance from Bigchain. * Fixed flake8 complaint about too many blank lines * Attempting to fix Sphinx docs. This may result in some redundant commits, as I don't know what I'm doing, and I can't experiment without running the CI... Sorry in advance! * Attempting to fix Sphinx docs. This may result in some redundant commits, as I don't know what I'm doing, and I can't experiment without running the CI... Sorry in advance! * Updating from master changed BigchainDB.process_post_response to a private method, so I had to align with that. * Fixed a couple stale references to bigchaindb.Bigchain in docstrings * Missed a reference to `Bigchain` in a patch call... * Problem: BigchainDB class should be part of project root Solution: Removed the /tendermint directory and moved its contents to project root * Problem: Flake8 complained that imports were not at the top of the file Solution: Had to play around with the order of imports to avoid cyclic dependencies, but its working and style compliant now * Problem: Stale reference to /tendermint directory in the index Solution: Removed the references to /tendermint * Problem: Flake8 complaining of unused import in __init__.py Solution: The import is there so I can import App directly from bigchaindb, rather than from bigchaindb.core (which I think improves code readability. I added a # noqa to silence Flake8. * Problem: Stale references to `bigchaindb.tendermint.BigchainDB` in the rst files cause Sphinx to fail Solution: Updated the autodoc files to use `bigchaindb.BigchainDB` instead * Problem: Stale reference to the `tendermint` directory in an @patch in a disabled test Solution: Updated the @patch for completeness * Problem: BigchainDB class should be part of project root Solution: Removed the /tendermint directory and moved its contents to project root * Problem: Flake8 complained that imports were not at the top of the file Solution: Had to play around with the order of imports to avoid cyclic dependencies, but its working and style compliant now * Problem: Stale reference to /tendermint directory in the index Solution: Removed the references to /tendermint * Problem: Flake8 complaining of unused import in __init__.py Solution: The import is there so I can import App directly from bigchaindb, rather than from bigchaindb.core (which I think improves code readability. I added a # noqa to silence Flake8. * Problem: Stale references to `bigchaindb.tendermint.BigchainDB` in the rst files cause Sphinx to fail Solution: Updated the autodoc files to use `bigchaindb.BigchainDB` instead * Problem: Stale reference to the `tendermint` directory in an @patch in a disabled test Solution: Updated the @patch for completeness
93 lines
2.7 KiB
Python
93 lines
2.7 KiB
Python
import pytest
|
|
|
|
from bigchaindb.models import Transaction
|
|
from bigchaindb.lib import Block
|
|
|
|
BLOCKS_ENDPOINT = '/api/v1/blocks/'
|
|
|
|
pytestmark = pytest.mark.tendermint
|
|
|
|
|
|
@pytest.mark.bdb
|
|
@pytest.mark.usefixtures('inputs')
|
|
def test_get_block_endpoint(tb, client, alice):
|
|
b = tb
|
|
tx = Transaction.create([alice.public_key], [([alice.public_key], 1)], asset={'cycle': 'hero'})
|
|
tx = tx.sign([alice.private_key])
|
|
b.store_transaction(tx)
|
|
|
|
block = Block(app_hash='random_utxo',
|
|
height=31,
|
|
transactions=[tx.id])
|
|
b.store_block(block._asdict())
|
|
|
|
res = client.get(BLOCKS_ENDPOINT + str(block.height))
|
|
expected_response = {'height': block.height, 'transactions': [tx.to_dict()]}
|
|
assert res.json == expected_response
|
|
assert res.status_code == 200
|
|
|
|
|
|
@pytest.mark.bdb
|
|
@pytest.mark.usefixtures('inputs')
|
|
def test_get_block_returns_404_if_not_found(client):
|
|
res = client.get(BLOCKS_ENDPOINT + '123')
|
|
assert res.status_code == 404
|
|
|
|
res = client.get(BLOCKS_ENDPOINT + '123/')
|
|
assert res.status_code == 404
|
|
|
|
|
|
@pytest.mark.bdb
|
|
def test_get_block_containing_transaction(tb, client, alice):
|
|
b = tb
|
|
tx = Transaction.create([alice.public_key], [([alice.public_key], 1)], asset={'cycle': 'hero'})
|
|
tx = tx.sign([alice.private_key])
|
|
b.store_transaction(tx)
|
|
|
|
block = Block(app_hash='random_utxo',
|
|
height=13,
|
|
transactions=[tx.id])
|
|
b.store_block(block._asdict())
|
|
|
|
res = client.get('{}?transaction_id={}'.format(BLOCKS_ENDPOINT, tx.id))
|
|
expected_response = [block.height]
|
|
assert res.json == expected_response
|
|
assert res.status_code == 200
|
|
|
|
|
|
@pytest.mark.bdb
|
|
def test_get_blocks_by_txid_endpoint_returns_empty_list_not_found(client):
|
|
res = client.get(BLOCKS_ENDPOINT + '?transaction_id=')
|
|
assert res.status_code == 200
|
|
assert len(res.json) == 0
|
|
|
|
res = client.get(BLOCKS_ENDPOINT + '?transaction_id=123')
|
|
assert res.status_code == 200
|
|
assert len(res.json) == 0
|
|
|
|
|
|
@pytest.mark.bdb
|
|
def test_get_blocks_by_txid_endpoint_returns_400_bad_query_params(client):
|
|
res = client.get(BLOCKS_ENDPOINT)
|
|
assert res.status_code == 400
|
|
|
|
res = client.get(BLOCKS_ENDPOINT + '?ts_id=123')
|
|
assert res.status_code == 400
|
|
assert res.json == {
|
|
'message': {
|
|
'transaction_id': 'Missing required parameter in the JSON body or the post body or the query string'
|
|
}
|
|
}
|
|
|
|
res = client.get(BLOCKS_ENDPOINT + '?transaction_id=123&foo=123')
|
|
assert res.status_code == 400
|
|
assert res.json == {
|
|
'message': 'Unknown arguments: foo'
|
|
}
|
|
|
|
res = client.get(BLOCKS_ENDPOINT + '?transaction_id=123&status=123')
|
|
assert res.status_code == 400
|
|
assert res.json == {
|
|
'message': 'Unknown arguments: status'
|
|
}
|