mirror of
https://github.com/planetmint/planetmint.git
synced 2025-03-30 15:08:31 +00:00

* assets changes * fixed init db code Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed some other test cases Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * Fixed 1/3 from test_queries.py * test_queries.py ALL PASSED * removed junk comment * test_schema.py fixed * added funcationilty to init a DB in case it hasn't been initialized before Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed test_schema.py * last commit * fixed some minor bugs Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * test_schema.py ALL PASSING + changes in TarantoolDB Class * test_schema.py ALL PASSING + changes in TarantoolDB Class * commit err * fixed asset issues Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed assets handling Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed missing Config().get() migrations Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed unit test error in case tx id is not defined Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed some minor bugs Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * simplified return of metadata Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * reconnect function added to reset_database if statement * removed some print * fixed TX compose bug about threshold information Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed usage of from_db part 1 Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed tarantool/tendermint status management Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed some backend init issues and error handling Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed output public_keys order bug Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed deepcopy bug and another small assignment bug Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * s * fixed last asset bug Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * merge * fixed another set of tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed test_core.py by converting dict transaction to Transaction Object * fixed delete_transaction function Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * commit * pre_commit_state singledispatch issue * fixed global variable of backend * fixed backend problem with command make tests * args_reset_db added, fixed error with incorrect handling of kwargs * test_validator passing * fixed test_core.py by adding HDict in saved_key_orders function * fixed pre_commiT-state bug * init chain recoginez function fixed . * fixed last error from tendermint/test_core.py * tendermint/test_core.py all passing * fixed function from fast_query.py, problem was in deleteting functions * fixed error from test_fastquery.py, by chaning the algorithm of verifying returnred transactions id * fixed test_core.py by adding HDict in saved_key_orders function Signed-off-by: Sangat Das <sangatdas5@gmail.com> * Fix make test issue - unhealthy planetmint container because non-init of tarantool spaces Signed-off-by: Sangat Das <sangatdas5@gmail.com> * Fix tarantool connection issues in test Signed-off-by: Sangat Das <sangatdas5@gmail.com> * _save_keys_order, changes behaviour * hash problem fixed * separated asset test fixed * Removed all Errors in Make Test Signed-off-by: Sangat Das <sangatdas5@gmail.com> * mock error solved * mock solved * problem with stdout from Popen * fixed output from calling subprocess * Now planetmint drop and planemint init, is working throught schema.py file. * Fixed some lib and web issues Signed-off-by: Sangat Das <sangatdas5@gmail.com> * test_lib test_update_utxoset passing * test_commands.py -> all tests are passing * test_queries.py -> fixed * rollback my changes * fixed test_quries.py -> problem with assets * test_quries.py -> metadata error fixed * test_bigchain_api -> fixed by adding ErrorHandling for Tarantool operation * test_bigchain_api * test_integration.py -> fixed issue with block object * test_lib.py -> fixed * store and get utxo fixed * NoneType error, fixed in test_lib.py * test_lib.py fixed error, adopting verification for tarantool * test_lib.py fixed one more function * test_store_bulk_transaction -> adopted for tarantool * test_store_transaction -> changed to work with tarantool * test_asset_is_separated_from_transaciton -> skipped for Tarantool connection type * Fixed 4 issues in test/tendermint Signed-off-by: Sangat Das <sangatdas5@gmail.com> * fixed merge issues Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed last misspelling of backend config Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * test_block_tendermint.py -> solved by returning empty list if not found * readded test_core tests, fixed some linter issues Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * last changes * removed test fixture * removed planetmint_env folder Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * .idea/ added to gitignore file * removed .idea/ folder from project * create 3 files. init: indexes, schema, tables(spaces). this is used for initializing space,index and schema separately, and getting an output for specific command * added to schema all execute commands in dictionary format * Added create_tables function for tarantool connection * 'create_database' function from schema file, is ignored using TarantoolDB Class. * Implemented planetmint init via schema.py ! * added execute drop commands for spaces * drop_databases improved * Removed .lua files that was created temporarily. * replaced TarantoolDB with TarantoolDBConnection Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * Added output to console for creating indexes. * fixed connection instantiation Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * Added exception for NetworkError, to get specific error from connection class. * _setup_database fixture restored.(STILL NOT WORKING in this commit) * added 'universe' name as database name for tarantool * created flush_db for tarantool connection type * function create_database will call create_tables only for tarantool connection * _bdb, setup_database restored as it was before * Fixed flush_dbtarantool * Fixed fatal crashing at beginning of starting planetmint. problem was solved by returning None value if where is no space. * adding try except to some queries from tarantool/query.py. * implemented decorator for running queries in try catch * removed import of interface * Removed print + removed import of interface directly * removed importing of interface * fixed some imports, refactored TarantoolDBConnection.conn handling Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added new requirement to setup.py * added query() method, that will return Lazy Object * removed unecessary comments from connection class * get_space method is the same as old space method. * Added run() method to TarantoolDBConnection Class. * tarantool/query.py changed for using Lazy() implementation + little changes * queries from tarantool/query.py was adjusted to not get NonType error * adjusted some function calls, and connection calls Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixes for error NoneType * fix for flush function (freezing of pytest) + NoneType error * store_transactions changed to use new format of query * Changed from .space() method to .get_space() * putted from new line * fixed Lazy() has no len * adjusted _group_transaction_by_ids and store_transactions for connection.run Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed .data from select queries Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed run_command_without_output config and removed faulty error handling Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * made rollback db agnostic * Added assign for pre_commit * resolved comments and clean-up of unused code * Fixed no attribute .run(). Fixed | Fixed no attribute .data * Fixed no atribute .data * Fixed list has no attribute .data * Removed comments * Fixed flush_db_tarantool, not it removes also from blocks spaces * Fixed test_queries.py PASSED * Fixed SystemExit error by inversing sorting of array * Cleaned up test_core.py * fixed upsert() functions, incorrect behaviour * removed unused print * removed unused print (2) * Fixed test_txlist.py by improving flush_db_tarantool * Small fixes in .upsert() functions for tarantool_db * Fixes some test cases in tendermint/test_lib.py * Fixed flush_tarantool_db Function. * added utxos to SPACE_NAMES to delete data from utxo space * fixed this module by restoring original function instructions. * added hash generation to create primary key for abci_chain tuple. * Added field 'id' to abci_chains * changed flush function to delete abci_chains tuples * added indexed_pattern_search to basic lua, implemented text_search Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * adjusted some queries, wip print statements to be removed Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed get_metadata Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added some prints and simplified code Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed __asset_check Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed print statements Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added limit to text_Search Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * Planetmint tarantool (#152) * added indexed_pattern_search to basic lua, implemented text_search Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * adjusted some queries, wip print statements to be removed Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed get_metadata Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added some prints and simplified code Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed __asset_check Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed print statements Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added limit to text_Search Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * adjusted store_asset behaviour to match mongodb implementation Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed test_write_metadata test case Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed pattern search for meta_data Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed text_search result conversion Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * adjusted connect config error handling and test case for new signature Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * Resolved issues related to key error * Added convert.py for storing interfaces * Added convert.py implementation for tarantool * Implemented to lib.py, functions from converted.py * Added initializing for convert.py * init of convert.py for mongodb implementation * implemented convert.py for mongodatabase [NOT TESTED] * adjusted get_assets and from_db for tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added comment Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fix get_assets issue (#160) * adjusted get_assets and from_db for tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added comment Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * resolve conflicts * docker all in one now install tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added user to integration init.lua Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated integration test setup for tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed print statements Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated changelog Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed error messaging Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed exception verification Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed printing of testdata Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * Planetmint tarantool (#169) * 31 restructue documentation (#138) * removed korean documentation Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed CN and KOR readme Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * changed to the press theme Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * first changes Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixe H3 vs H1 issues Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added missing png Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added missing file Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed warnings Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * moved documents Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obsolete files Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obsolete folder Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obs. file Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added some final changes Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obs. reference Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * moved chain migration to election types (#109) Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * Final zenroom (#147) * zenroom fixes Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * expl. defined the aiohttp package Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * increased version number and fixed a zenroom runtime bug Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added fialing zenroom tx signing test Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * extended test to pass zenrooom validation, but to fail planetmint validation. Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added manual tx crafting Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added zenroom fulfillment verification Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * the last mile before integration Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * zenroom unit tests are passing Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * simplified zenroom unit tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obsolte lines from the zenroom tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed acceptance tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * adjusted zenroom integraiton tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed linting errors Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * simplified zenroom unit test Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * increased version number Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * using cryptoconditions without print message Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * increased cc usage to 0.9.9 readded daemon proceses Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * increased version to 0.9.6 Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed deployment issue for 0.9.6 Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * adjusted get_assets and from_db for tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added comment Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * improve usability of zenroom (#159) * improve usability of zenroom * * increased version * fixed test cases * added changelog Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> Co-authored-by: Jürgen Eckel <juergen@riddleandcode.com> * migrated to AGPLv3 Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * 150 add cryptoconditions documentation (#166) * added smaller logos fixed reference issue Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed some erros and typos Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added cryptoconditions reference to the subproject Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * docker all in one now install tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added user to integration init.lua Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated integration test setup for tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed print statements Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated changelog Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed error messaging Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed exception verification Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed printing of testdata Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> Co-authored-by: Jürgen Eckel <eckelj@users.noreply.github.com> Co-authored-by: Lorenz Herzberger <64837895+LaurentDeMontBlanc@users.noreply.github.com> Co-authored-by: Alberto Lerda <30939098+albertolerda@users.noreply.github.com> Co-authored-by: Jürgen Eckel <juergen@riddleandcode.com> * Removing naughty strings test cases * updated quickstart with tarantool installation Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated all-in-one-planetmint with tarantool port and data persistence Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed typo Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * update documentation about tarantool (#174) * 31 restructue documentation (#138) * removed korean documentation Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed CN and KOR readme Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * changed to the press theme Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * first changes Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixe H3 vs H1 issues Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added missing png Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added missing file Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed warnings Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * moved documents Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obsolete files Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obsolete folder Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obs. file Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added some final changes Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obs. reference Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * moved chain migration to election types (#109) Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * Final zenroom (#147) * zenroom fixes Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * expl. defined the aiohttp package Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * increased version number and fixed a zenroom runtime bug Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added fialing zenroom tx signing test Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * extended test to pass zenrooom validation, but to fail planetmint validation. Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added manual tx crafting Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added zenroom fulfillment verification Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * the last mile before integration Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * zenroom unit tests are passing Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * simplified zenroom unit tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * removed obsolte lines from the zenroom tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed acceptance tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * adjusted zenroom integraiton tests Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed linting errors Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * simplified zenroom unit test Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * increased version number Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * using cryptoconditions without print message Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * increased cc usage to 0.9.9 readded daemon proceses Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * increased version to 0.9.6 Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed deployment issue for 0.9.6 Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * adjusted get_assets and from_db for tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added comment Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * improve usability of zenroom (#159) * improve usability of zenroom * * increased version * fixed test cases * added changelog Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> Co-authored-by: Jürgen Eckel <juergen@riddleandcode.com> * migrated to AGPLv3 Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * 150 add cryptoconditions documentation (#166) * added smaller logos fixed reference issue Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed some erros and typos Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * added cryptoconditions reference to the subproject Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * docker all in one now install tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * added user to integration init.lua Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated integration test setup for tarantool Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * removed print statements Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated changelog Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed error messaging Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed exception verification Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * fixed printing of testdata Signed-off-by: Jürgen Eckel <juergen@riddleandcode.com> * updated quickstart with tarantool installation Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * updated all-in-one-planetmint with tarantool port and data persistence Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> * fixed typo Signed-off-by: Lorenz Herzberger <lorenzherzberger@gmail.com> Co-authored-by: Jürgen Eckel <eckelj@users.noreply.github.com> Co-authored-by: Lorenz Herzberger <64837895+LaurentDeMontBlanc@users.noreply.github.com> Co-authored-by: Alberto Lerda <30939098+albertolerda@users.noreply.github.com> Co-authored-by: Jürgen Eckel <juergen@riddleandcode.com> * Fixes lint issues (#176) * Resolved lint issues * resolved other lint issues Co-authored-by: Jürgen Eckel <juergen@riddleandcode.com> Co-authored-by: andrei <deffuls@debian-BULLSEYE-live-builder-AMD64> Co-authored-by: Sangat Das <sangatdas5@gmail.com> Co-authored-by: liviu-lesan <31960632+liviu-lesan@users.noreply.github.com> Co-authored-by: Lorenz Herzberger <64837895+LaurentDeMontBlanc@users.noreply.github.com> Co-authored-by: andreitricolici <97448537+andreitricolici@users.noreply.github.com> Co-authored-by: ArpitShukla007 <arpitnshukla@gmail.com> Co-authored-by: Jürgen Eckel <eckelj@users.noreply.github.com> Co-authored-by: Alberto Lerda <30939098+albertolerda@users.noreply.github.com>
514 lines
17 KiB
Python
514 lines
17 KiB
Python
# Copyright © 2020 Interplanetary Database Association e.V.,
|
|
# Planetmint and IPDB software contributors.
|
|
# SPDX-License-Identifier: (Apache-2.0 AND CC-BY-4.0)
|
|
# Code is Apache-2.0 and docs are CC-BY-4.0
|
|
|
|
import json
|
|
from unittest.mock import Mock, patch
|
|
|
|
import base58
|
|
import pytest
|
|
from cryptoconditions import Ed25519Sha256
|
|
|
|
try:
|
|
from hashlib import sha3_256
|
|
except ImportError:
|
|
from sha3 import sha3_256
|
|
|
|
from planetmint.transactions.common import crypto
|
|
from planetmint.transactions.types.assets.create import Create
|
|
from planetmint.transactions.types.assets.transfer import Transfer
|
|
from planetmint.transactions.common.transaction_mode_types import (
|
|
BROADCAST_TX_COMMIT,
|
|
BROADCAST_TX_ASYNC,
|
|
BROADCAST_TX_SYNC,
|
|
)
|
|
|
|
TX_ENDPOINT = "/api/v1/transactions/"
|
|
|
|
|
|
@pytest.mark.abci
|
|
def test_get_transaction_endpoint(client, posted_create_tx):
|
|
res = client.get(TX_ENDPOINT + posted_create_tx.id)
|
|
assert posted_create_tx.to_dict() == res.json
|
|
assert res.status_code == 200
|
|
|
|
|
|
def test_get_transaction_returns_404_if_not_found(client):
|
|
res = client.get(TX_ENDPOINT + "123")
|
|
assert res.status_code == 404
|
|
|
|
res = client.get(TX_ENDPOINT + "123/")
|
|
assert res.status_code == 404
|
|
|
|
|
|
@pytest.mark.abci
|
|
def test_post_create_transaction_endpoint(b, client):
|
|
user_priv, user_pub = crypto.generate_key_pair()
|
|
|
|
tx = Create.generate([user_pub], [([user_pub], 1)])
|
|
tx = tx.sign([user_priv])
|
|
|
|
res = client.post(TX_ENDPOINT, data=json.dumps(tx.to_dict()))
|
|
|
|
assert res.status_code == 202
|
|
|
|
assert res.json["inputs"][0]["owners_before"][0] == user_pub
|
|
assert res.json["outputs"][0]["public_keys"][0] == user_pub
|
|
|
|
|
|
@pytest.mark.abci
|
|
@pytest.mark.parametrize("nested", [False, True])
|
|
@pytest.mark.parametrize(
|
|
"language,expected_status_code",
|
|
[
|
|
("danish", 202),
|
|
("dutch", 202),
|
|
("english", 202),
|
|
("finnish", 202),
|
|
("french", 202),
|
|
("german", 202),
|
|
("hungarian", 202),
|
|
("italian", 202),
|
|
("norwegian", 202),
|
|
("portuguese", 202),
|
|
("romanian", 202),
|
|
("none", 202),
|
|
("russian", 202),
|
|
("spanish", 202),
|
|
("swedish", 202),
|
|
("turkish", 202),
|
|
("da", 202),
|
|
("nl", 202),
|
|
("en", 202),
|
|
("fi", 202),
|
|
("fr", 202),
|
|
("de", 202),
|
|
("hu", 202),
|
|
("it", 202),
|
|
("nb", 202),
|
|
("pt", 202),
|
|
("ro", 202),
|
|
("ru", 202),
|
|
("es", 202),
|
|
("sv", 202),
|
|
("tr", 202),
|
|
("any", 400),
|
|
],
|
|
)
|
|
@pytest.mark.language
|
|
def test_post_create_transaction_with_language(
|
|
b, client, nested, language, expected_status_code
|
|
):
|
|
from planetmint.backend.localmongodb.connection import LocalMongoDBConnection
|
|
|
|
if isinstance(b.connection, LocalMongoDBConnection):
|
|
user_priv, user_pub = crypto.generate_key_pair()
|
|
lang_obj = {"language": language}
|
|
|
|
if nested:
|
|
asset = {"root": lang_obj}
|
|
else:
|
|
asset = lang_obj
|
|
|
|
tx = Create.generate([user_pub], [([user_pub], 1)], asset=asset)
|
|
tx = tx.sign([user_priv])
|
|
res = client.post(TX_ENDPOINT, data=json.dumps(tx.to_dict()))
|
|
assert res.status_code == expected_status_code
|
|
if res.status_code == 400:
|
|
expected_error_message = (
|
|
"Invalid transaction (ValidationError): MongoDB does not support "
|
|
'text search for the language "{}". If you do not understand this '
|
|
'error message then please rename key/field "language" to something '
|
|
'else like "lang".'
|
|
).format(language)
|
|
assert res.json["message"] == expected_error_message
|
|
|
|
|
|
@pytest.mark.abci
|
|
@pytest.mark.parametrize("field", ["asset", "metadata"])
|
|
@pytest.mark.parametrize(
|
|
"value,err_key,expected_status_code",
|
|
[
|
|
({"bad.key": "v"}, "bad.key", 400),
|
|
({"$bad.key": "v"}, "$bad.key", 400),
|
|
({"$badkey": "v"}, "$badkey", 400),
|
|
({"bad\x00key": "v"}, "bad\x00key", 400),
|
|
({"good_key": {"bad.key": "v"}}, "bad.key", 400),
|
|
({"good_key": "v"}, "good_key", 202),
|
|
],
|
|
)
|
|
def test_post_create_transaction_with_invalid_key(
|
|
b, client, field, value, err_key, expected_status_code
|
|
):
|
|
from planetmint.backend.localmongodb.connection import LocalMongoDBConnection
|
|
|
|
user_priv, user_pub = crypto.generate_key_pair()
|
|
|
|
if isinstance(b.connection, LocalMongoDBConnection):
|
|
if field == "asset":
|
|
tx = Create.generate([user_pub], [([user_pub], 1)], asset=value)
|
|
elif field == "metadata":
|
|
tx = Create.generate([user_pub], [([user_pub], 1)], metadata=value)
|
|
tx = tx.sign([user_priv])
|
|
res = client.post(TX_ENDPOINT, data=json.dumps(tx.to_dict()))
|
|
|
|
assert res.status_code == expected_status_code
|
|
|
|
if res.status_code == 400:
|
|
expected_error_message = (
|
|
'Invalid transaction (ValidationError): Invalid key name "{}" '
|
|
"in {} object. The key name cannot contain characters "
|
|
'".", "$" or null characters'
|
|
).format(err_key, field)
|
|
assert res.json["message"] == expected_error_message
|
|
|
|
|
|
@pytest.mark.abci
|
|
@patch("planetmint.web.views.base.logger")
|
|
def test_post_create_transaction_with_invalid_id(mock_logger, b, client):
|
|
from planetmint.transactions.common.exceptions import InvalidHash
|
|
|
|
user_priv, user_pub = crypto.generate_key_pair()
|
|
|
|
tx = Create.generate([user_pub], [([user_pub], 1)])
|
|
tx = tx.sign([user_priv]).to_dict()
|
|
tx["id"] = "abcd" * 16
|
|
|
|
res = client.post(TX_ENDPOINT, data=json.dumps(tx))
|
|
expected_status_code = 400
|
|
expected_error_message = (
|
|
"Invalid transaction ({}): The transaction's id '{}' isn't equal to "
|
|
"the hash of its body, i.e. it's not valid."
|
|
).format(InvalidHash.__name__, tx["id"])
|
|
assert res.status_code == expected_status_code
|
|
assert res.json["message"] == expected_error_message
|
|
assert mock_logger.error.called
|
|
assert (
|
|
"HTTP API error: %(status)s - %(method)s:%(path)s - %(message)s"
|
|
in mock_logger.error.call_args[0]
|
|
)
|
|
assert {
|
|
"message": expected_error_message,
|
|
"status": expected_status_code,
|
|
"method": "POST",
|
|
"path": TX_ENDPOINT,
|
|
} in mock_logger.error.call_args[0]
|
|
# TODO put back caplog based asserts once possible
|
|
# assert caplog.records[0].args['status'] == expected_status_code
|
|
# assert caplog.records[0].args['message'] == expected_error_message
|
|
|
|
|
|
@pytest.mark.abci
|
|
@patch("planetmint.web.views.base.logger")
|
|
def test_post_create_transaction_with_invalid_signature(mock_logger, b, client):
|
|
from planetmint.transactions.common.exceptions import InvalidSignature
|
|
|
|
user_priv, user_pub = crypto.generate_key_pair()
|
|
|
|
tx = Create.generate([user_pub], [([user_pub], 1)]).to_dict()
|
|
tx["inputs"][0]["fulfillment"] = 64 * "0"
|
|
tx["id"] = sha3_256(
|
|
json.dumps(
|
|
tx,
|
|
sort_keys=True,
|
|
separators=(",", ":"),
|
|
ensure_ascii=False,
|
|
).encode(),
|
|
).hexdigest()
|
|
|
|
res = client.post(TX_ENDPOINT, data=json.dumps(tx))
|
|
expected_status_code = 400
|
|
expected_error_message = (
|
|
"Invalid transaction ({}): Fulfillment URI " "couldn't been parsed"
|
|
).format(InvalidSignature.__name__)
|
|
assert res.status_code == expected_status_code
|
|
assert res.json["message"] == expected_error_message
|
|
assert mock_logger.error.called
|
|
assert (
|
|
"HTTP API error: %(status)s - %(method)s:%(path)s - %(message)s"
|
|
in mock_logger.error.call_args[0]
|
|
)
|
|
assert {
|
|
"message": expected_error_message,
|
|
"status": expected_status_code,
|
|
"method": "POST",
|
|
"path": TX_ENDPOINT,
|
|
} in mock_logger.error.call_args[0]
|
|
# TODO put back caplog based asserts once possible
|
|
# assert caplog.records[0].args['status'] == expected_status_code
|
|
# assert caplog.records[0].args['message'] == expected_error_message
|
|
|
|
|
|
@pytest.mark.abci
|
|
def test_post_create_transaction_with_invalid_structure(client):
|
|
res = client.post(TX_ENDPOINT, data="{}")
|
|
assert res.status_code == 400
|
|
|
|
|
|
@pytest.mark.abci
|
|
@patch("planetmint.web.views.base.logger")
|
|
def test_post_create_transaction_with_invalid_schema(mock_logger, client):
|
|
user_priv, user_pub = crypto.generate_key_pair()
|
|
tx = Create.generate([user_pub], [([user_pub], 1)]).to_dict()
|
|
del tx["version"]
|
|
ed25519 = Ed25519Sha256(public_key=base58.b58decode(user_pub))
|
|
message = json.dumps(
|
|
tx,
|
|
sort_keys=True,
|
|
separators=(",", ":"),
|
|
ensure_ascii=False,
|
|
).encode()
|
|
ed25519.sign(message, base58.b58decode(user_priv))
|
|
tx["inputs"][0]["fulfillment"] = ed25519.serialize_uri()
|
|
tx["id"] = sha3_256(
|
|
json.dumps(
|
|
tx,
|
|
sort_keys=True,
|
|
separators=(",", ":"),
|
|
ensure_ascii=False,
|
|
).encode(),
|
|
).hexdigest()
|
|
res = client.post(TX_ENDPOINT, data=json.dumps(tx))
|
|
expected_status_code = 400
|
|
expected_error_message = (
|
|
# "Invalid transaction schema: 'version' is a required property"
|
|
"Invalid transaction (KeyError): 'version'"
|
|
)
|
|
assert res.status_code == expected_status_code
|
|
assert res.json["message"] == expected_error_message
|
|
assert mock_logger.error.called
|
|
assert (
|
|
"HTTP API error: %(status)s - %(method)s:%(path)s - %(message)s"
|
|
in mock_logger.error.call_args[0]
|
|
)
|
|
assert {
|
|
"message": expected_error_message,
|
|
"status": expected_status_code,
|
|
"method": "POST",
|
|
"path": TX_ENDPOINT,
|
|
} in mock_logger.error.call_args[0]
|
|
# TODO put back caplog based asserts once possible
|
|
# assert caplog.records[0].args['status'] == expected_status_code
|
|
# assert caplog.records[0].args['message'] == expected_error_message
|
|
|
|
|
|
@pytest.mark.abci
|
|
@pytest.mark.parametrize(
|
|
"exc,msg",
|
|
(
|
|
("AmountError", "Do the math again!"),
|
|
("DoubleSpend", "Nope! It is gone now!"),
|
|
("InvalidHash", "Do not smoke that!"),
|
|
("InvalidSignature", "Falsche Unterschrift!"),
|
|
("ValidationError", "Create and transfer!"),
|
|
("InputDoesNotExist", "Hallucinations?"),
|
|
("TransactionOwnerError", "Not yours!"),
|
|
("ValidationError", "?"),
|
|
),
|
|
)
|
|
@patch("planetmint.web.views.base.logger")
|
|
def test_post_invalid_transaction(
|
|
mock_logger,
|
|
client,
|
|
exc,
|
|
msg,
|
|
monkeypatch,
|
|
):
|
|
from planetmint.transactions.common import exceptions
|
|
|
|
exc_cls = getattr(exceptions, exc)
|
|
|
|
def mock_validation(self_, tx):
|
|
raise exc_cls(msg)
|
|
|
|
TransactionMock = Mock(validate=mock_validation)
|
|
|
|
monkeypatch.setattr(
|
|
"planetmint.models.Transaction.from_dict", lambda tx: TransactionMock
|
|
)
|
|
res = client.post(TX_ENDPOINT, data=json.dumps({}))
|
|
expected_status_code = 400
|
|
expected_error_message = "Invalid transaction ({}): {}".format(exc, msg)
|
|
assert res.status_code == expected_status_code
|
|
assert res.json["message"] == "Invalid transaction ({}): {}".format(exc, msg)
|
|
assert mock_logger.error.called
|
|
assert (
|
|
"HTTP API error: %(status)s - %(method)s:%(path)s - %(message)s"
|
|
in mock_logger.error.call_args[0]
|
|
)
|
|
assert {
|
|
"message": expected_error_message,
|
|
"status": expected_status_code,
|
|
"method": "POST",
|
|
"path": TX_ENDPOINT,
|
|
} in mock_logger.error.call_args[0]
|
|
# TODO put back caplog based asserts once possible
|
|
# assert caplog.records[2].args['status'] == expected_status_code
|
|
# assert caplog.records[2].args['message'] == expected_error_message
|
|
|
|
|
|
@pytest.mark.abci
|
|
def test_post_transfer_transaction_endpoint(client, user_pk, user_sk, posted_create_tx):
|
|
|
|
transfer_tx = Transfer.generate(
|
|
posted_create_tx.to_inputs(), [([user_pk], 1)], asset_id=posted_create_tx.id
|
|
)
|
|
transfer_tx = transfer_tx.sign([user_sk])
|
|
|
|
res = client.post(TX_ENDPOINT, data=json.dumps(transfer_tx.to_dict()))
|
|
|
|
assert res.status_code == 202
|
|
|
|
assert res.json["inputs"][0]["owners_before"][0] == user_pk
|
|
assert res.json["outputs"][0]["public_keys"][0] == user_pk
|
|
|
|
|
|
@pytest.mark.abci
|
|
def test_post_invalid_transfer_transaction_returns_400(
|
|
client, user_pk, posted_create_tx
|
|
):
|
|
from planetmint.transactions.common.exceptions import InvalidSignature
|
|
|
|
transfer_tx = Transfer.generate(
|
|
posted_create_tx.to_inputs(), [([user_pk], 1)], asset_id=posted_create_tx.id
|
|
)
|
|
transfer_tx._hash()
|
|
|
|
res = client.post(TX_ENDPOINT, data=json.dumps(transfer_tx.to_dict()))
|
|
expected_status_code = 400
|
|
expected_error_message = "Invalid transaction ({}): {}".format(
|
|
InvalidSignature.__name__, "Transaction signature is invalid."
|
|
)
|
|
assert res.status_code == expected_status_code
|
|
assert res.json["message"] == expected_error_message
|
|
|
|
|
|
@pytest.mark.abci
|
|
def test_post_wrong_asset_division_transfer_returns_400(b, client, user_pk):
|
|
from planetmint.transactions.common.exceptions import AmountError
|
|
|
|
priv_key, pub_key = crypto.generate_key_pair()
|
|
|
|
create_tx = Create.generate(
|
|
[pub_key], [([pub_key], 10)], asset={"test": "asset"}
|
|
).sign([priv_key])
|
|
res = client.post(
|
|
TX_ENDPOINT + "?mode=commit", data=json.dumps(create_tx.to_dict())
|
|
)
|
|
assert res.status_code == 202
|
|
|
|
transfer_tx = Transfer.generate(
|
|
create_tx.to_inputs(), [([pub_key], 20)], asset_id=create_tx.id # 20 > 10
|
|
).sign([priv_key])
|
|
res = client.post(
|
|
TX_ENDPOINT + "?mode=commit", data=json.dumps(transfer_tx.to_dict())
|
|
)
|
|
expected_error_message = (
|
|
f"Invalid transaction ({AmountError.__name__}): "
|
|
+ "The amount used in the inputs `10` needs to be same as the amount used in the outputs `20`"
|
|
)
|
|
|
|
assert res.status_code == 400
|
|
assert res.json["message"] == expected_error_message
|
|
|
|
|
|
def test_transactions_get_list_good(client):
|
|
from functools import partial
|
|
|
|
def get_txs_patched(conn, **args):
|
|
"""Patch `get_transactions_filtered` so that rather than return an array
|
|
of transactions it returns an array of shims with a to_dict() method
|
|
that reports one of the arguments passed to `get_transactions_filtered`.
|
|
"""
|
|
return [
|
|
type("", (), {"to_dict": partial(lambda a: a, arg)})
|
|
for arg in sorted(args.items())
|
|
]
|
|
|
|
asset_id = "1" * 64
|
|
|
|
with patch("planetmint.Planetmint.get_transactions_filtered", get_txs_patched):
|
|
url = TX_ENDPOINT + "?asset_id=" + asset_id
|
|
assert client.get(url).json == [
|
|
["asset_id", asset_id],
|
|
["last_tx", None],
|
|
["operation", None],
|
|
]
|
|
url = TX_ENDPOINT + "?asset_id=" + asset_id + "&operation=CREATE"
|
|
assert client.get(url).json == [
|
|
["asset_id", asset_id],
|
|
["last_tx", None],
|
|
["operation", "CREATE"],
|
|
]
|
|
url = TX_ENDPOINT + "?asset_id=" + asset_id + "&last_tx=true"
|
|
assert client.get(url).json == [
|
|
["asset_id", asset_id],
|
|
["last_tx", True],
|
|
["operation", None],
|
|
]
|
|
|
|
|
|
def test_transactions_get_list_bad(client):
|
|
def should_not_be_called():
|
|
assert False
|
|
|
|
with patch(
|
|
"planetmint.Planetmint.get_transactions_filtered",
|
|
lambda *_, **__: should_not_be_called(),
|
|
):
|
|
# Test asset id validated
|
|
url = TX_ENDPOINT + "?asset_id=" + "1" * 63
|
|
assert client.get(url).status_code == 400
|
|
# Test operation validated
|
|
url = TX_ENDPOINT + "?asset_id=" + "1" * 64 + "&operation=CEATE"
|
|
assert client.get(url).status_code == 400
|
|
# Test asset ID required
|
|
url = TX_ENDPOINT + "?operation=CREATE"
|
|
assert client.get(url).status_code == 400
|
|
|
|
|
|
@patch("requests.post")
|
|
@pytest.mark.parametrize(
|
|
"mode",
|
|
[
|
|
("", BROADCAST_TX_ASYNC),
|
|
("?mode=async", BROADCAST_TX_ASYNC),
|
|
("?mode=sync", BROADCAST_TX_SYNC),
|
|
("?mode=commit", BROADCAST_TX_COMMIT),
|
|
],
|
|
)
|
|
def test_post_transaction_valid_modes(mock_post, client, mode):
|
|
from planetmint.transactions.common.crypto import generate_key_pair
|
|
|
|
def _mock_post(*args, **kwargs):
|
|
return Mock(json=Mock(return_value={"result": {"code": 0}}))
|
|
|
|
mock_post.side_effect = _mock_post
|
|
|
|
alice = generate_key_pair()
|
|
tx = Create.generate(
|
|
[alice.public_key], [([alice.public_key], 1)], asset=None
|
|
).sign([alice.private_key])
|
|
mode_endpoint = TX_ENDPOINT + mode[0]
|
|
client.post(mode_endpoint, data=json.dumps(tx.to_dict()))
|
|
args, kwargs = mock_post.call_args
|
|
assert mode[1] == kwargs["json"]["method"]
|
|
|
|
|
|
@pytest.mark.abci
|
|
def test_post_transaction_invalid_mode(client):
|
|
from planetmint.transactions.common.crypto import generate_key_pair
|
|
|
|
alice = generate_key_pair()
|
|
tx = Create.generate(
|
|
[alice.public_key], [([alice.public_key], 1)], asset=None
|
|
).sign([alice.private_key])
|
|
mode_endpoint = TX_ENDPOINT + "?mode=nope"
|
|
response = client.post(mode_endpoint, data=json.dumps(tx.to_dict()))
|
|
assert "400 BAD REQUEST" in response.status
|
|
assert (
|
|
'Mode must be "async", "sync" or "commit"'
|
|
== json.loads(response.data.decode("utf8"))["message"]["mode"]
|
|
)
|