Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Gh 468 #545 - actions run #548

Open
wants to merge 114 commits into
base: GH-784
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
114 commits
Select commit Hold shift + click to select a range
77d9cd9
continue of code review changes
czarte Jul 17, 2024
c974b66
test for panic in handle_retrieve_transactions
czarte Jul 19, 2024
c859541
fixing more comments from review
czarte Jul 23, 2024
3c93749
removing TODO
czarte Jul 23, 2024
0d50bbe
implementing review, added two new tests for ip_country
czarte Jul 24, 2024
15fa3ee
removing unnecesary country_code from node_descriptor
czarte Jul 26, 2024
4c2d57b
added cfg(test) and cfg(not(test)) for static ref COUNTRY_CODE_FINDER…
czarte Jul 26, 2024
75fb708
change country_code member of NodeRecordInner_0v1 to country_code_opt
czarte Jul 26, 2024
78cc0c2
simplifying tests in node_record.rs and neighborhood_database.rs
czarte Jul 26, 2024
fe8a9b4
resolving review comments
czarte Jul 30, 2024
bf10d81
final changes in gossip_acceptor from review
czarte Jul 31, 2024
bec7b8b
continue of implementing review comments
czarte Jul 31, 2024
1a74962
fix test return value
czarte Jul 31, 2024
f750f01
added ip_country to ci/all.sh
czarte Aug 7, 2024
002a311
cherry-pick from GH-784-fix-for-Vojta and implementing iterator for d…
czarte Aug 7, 2024
7cd7c0d
try to create test for fmt
czarte Aug 7, 2024
bc7a6cc
tests for print ip v4 and v6 vec[u8] in country_block_serde.rs
czarte Aug 8, 2024
69f79c5
ci for ip_country + resolved conflicts of clippy
czarte Aug 13, 2024
b0d8958
masq_lib dependencies solved
czarte Aug 14, 2024
f549131
dependency masq_lib for ip_country in node workspace
czarte Aug 14, 2024
ac3f186
remove commented out code + fix condition for non empty bit_queue
czarte Aug 14, 2024
e72ae56
formatting
czarte Aug 14, 2024
f5bb091
5 seconds for wait_for_log in requested_chain_meets_different_db_chai…
czarte Aug 15, 2024
2771e36
fixing impl for AGR in multinode tests
czarte Aug 15, 2024
715587e
formatting
czarte Aug 15, 2024
44db161
fix nonexistent NodeAddr in multinode tests for AGR
czarte Aug 16, 2024
d5307f3
change single match to if
czarte Aug 16, 2024
201cced
try to fix build in actions for MacOS
czarte Aug 19, 2024
e974e67
try to find out disk space on MacOS container in Actions
czarte Aug 19, 2024
f5f4afc
add diagnostics commands on failure
czarte Aug 19, 2024
859452b
check diskspace before ci/all.sh workflow runs
czarte Aug 19, 2024
6627715
diagnose mounted disks
czarte Aug 19, 2024
3ce6ac3
analyze /var/ diskspace
czarte Aug 19, 2024
b350db9
remove advanced diagnosticst for disk space
czarte Aug 20, 2024
8463d3d
switch macos to version 13
czarte Aug 20, 2024
7406b6f
diagnostics for /Users/runner/work/Node/Node/node/target/release
czarte Aug 21, 2024
9dd7982
fasten diagnostics
czarte Aug 21, 2024
e316e6c
fasten diagnostics fix
czarte Aug 21, 2024
c803f56
fasten diagnostics back
czarte Aug 21, 2024
b85253a
test for mac-os build without masq_lib for ip_country
czarte Aug 21, 2024
26c67c4
remove masq_lib from ip_country
czarte Aug 21, 2024
92bcc5b
starting with UI setup for Exit Location
czarte Aug 22, 2024
b9d07b3
GH-784-review-two-state: fixes that could work on Actions, appeasing it
Aug 23, 2024
6b4e775
fixing review
czarte Aug 30, 2024
b7553ad
implementing CountryBlock count in generated rs file, and infrastructure
czarte Aug 30, 2024
68719e3
fixing ip_country tests
czarte Aug 30, 2024
48a3857
fix import of ip_country to multinode_integration_tests
czarte Sep 2, 2024
56d6010
formatting
czarte Sep 2, 2024
5b44e6b
fix the reference for COUNTRY_CODE_FINDER
czarte Sep 2, 2024
a956ff2
merget GH-784-review-two-state into branch
czarte Sep 5, 2024
16f5bfa
exit location for shared_schema, set_configuration_command, configura…
czarte Sep 5, 2024
15b0c9a
tests for persistent_configurator_mock, and valdator ..string_u64_val…
czarte Sep 9, 2024
aa4e579
test for trigger todo for implement validate_parameter_with_separate_…
czarte Sep 10, 2024
719af15
add ip_country dependency to masq_lib, validation for exit-location i…
czarte Sep 10, 2024
b6c0c26
validate pipe separated values with closure from particular validators
czarte Sep 11, 2024
bd61b23
starting work on neighborhood modification
czarte Sep 12, 2024
2f518d6
implementing exit_location
czarte Sep 17, 2024
b5a3622
ExitLocation struct and its members to messages.rs, set_exit_location…
czarte Sep 20, 2024
2c3a3dd
implemented country-codes and fallback-routing into MessageBody for N…
czarte Sep 23, 2024
a62fea7
completed test for c
czarte Sep 24, 2024
fdcfcab
implemented handler for exit_location_opt, rename exit_loctation to e…
czarte Sep 29, 2024
85a3835
fmt for HashSet<ExitLocation>, finished the assertions in test exit_l…
czarte Sep 29, 2024
c4890f2
cleanup, test for fallback-routing: false, logger for fallback-routin…
czarte Sep 29, 2024
304363a
change exit_locations_opt from HashSet to HashMap
czarte Sep 30, 2024
acf9999
clearing bootstrapper config
czarte Oct 1, 2024
88306ae
added member for NodeRecordMetadata and processing for country_undesi…
czarte Oct 2, 2024
39b2c5b
added assertion message for assert on db change in actor
czarte Oct 2, 2024
52a659a
refacotring neighborhood_test_utils: extracted make_segmented_ip, and…
czarte Oct 3, 2024
7d65f9b
added unset exit_location logic with test
czarte Oct 3, 2024
6152a9e
change name of test
czarte Oct 3, 2024
5bc34df
merge GH-784 into GH-468
czarte Oct 3, 2024
6578185
fiixing tests for set_exit_location_command, fixing log assertion for…
czarte Oct 4, 2024
fe74815
added assertion on neighborhood to exit_location tests
czarte Oct 7, 2024
e7be714
pull request branch changed to GH-784
czarte Oct 7, 2024
d2adbfe
formatting
czarte Oct 7, 2024
2c09618
fixing comments from review
czarte Oct 7, 2024
867134b
polishing helps
czarte Oct 8, 2024
9a4c1a0
addressing comments from review
czarte Oct 8, 2024
5a234df
polishing helps for exit-location
czarte Oct 9, 2024
9e1c1c7
add use super::*; to tests use
czarte Oct 9, 2024
fff1c3d
add cfg(test) for tests in set_exit_location_command
czarte Oct 9, 2024
3456b2e
fixing clippy complains
czarte Oct 10, 2024
516712a
fix multinode neighborhood constructor
czarte Oct 10, 2024
24ab306
rename set_exit_location_command.rs to exit_location_command.rs
czarte Oct 10, 2024
f14ab6d
add protection for empty Neighborhood DB
czarte Oct 10, 2024
4be9596
change protection for empty Neighborhood
czarte Oct 10, 2024
9a4c687
fixed shared schema, added exit location to --help of masq
czarte Oct 11, 2024
eb3ca81
set version for sccache
czarte Oct 14, 2024
aa01112
add lifetime for daemon_shared_app fn return
czarte Oct 14, 2024
c3e36f2
fixing log assertion in tests, add db to exit location test, fix app …
czarte Oct 14, 2024
129ec37
introduce test utilities
czarte Oct 15, 2024
7174c9f
remove unused import - localhost linux compile and passes all ip_coun…
czarte Oct 16, 2024
e21b545
addressing comments from review
czarte Oct 17, 2024
9208137
addressing comments from review, refactoring Neighborhood for exit-lo…
czarte Oct 21, 2024
0771086
fix tests for separate_u64_values
czarte Oct 22, 2024
60dc65a
add Eq to ExitPreference
czarte Oct 22, 2024
de2a90d
rearranged test_utilities, fix to exit_location_handler and its tests
czarte Oct 22, 2024
6307d39
fixing ByteArrayWriter and Reader for masq
czarte Oct 23, 2024
34ee03b
added more nodes to exit_location test with fallback to test UNREACHA…
czarte Oct 23, 2024
b85eaf5
move test_utilities to dev-dependencies
czarte Oct 24, 2024
56ae969
test_utilities from dev to production dependencies in masq_lib
czarte Oct 24, 2024
9932e02
formatting help
czarte Oct 25, 2024
c628ca8
formatting help
czarte Oct 25, 2024
0da1a22
review 3 - refactoring message handler for exit location, and few min…
czarte Oct 25, 2024
4a53523
country codes for NodeRecords in tests Neighborhood DBs, constants fo…
czarte Oct 27, 2024
c2e57dc
formatting
czarte Oct 28, 2024
c024595
fix todo comment, and formatting
czarte Oct 29, 2024
dddc69a
exit-loaction data structures moved into the ExitTools, cloned into N…
czarte Oct 30, 2024
2474e75
implemented adding country_undesirability for introducer and debutant
czarte Oct 31, 2024
6f4c6d1
formatting and remove unnecesary let
czarte Nov 1, 2024
e43083f
fallback routing assertion change
czarte Nov 1, 2024
cc24a1f
formatting
czarte Nov 1, 2024
a7351e6
rename ExitTools
czarte Nov 3, 2024
641001e
fix request for neverssl.com to impersonate user-agent
czarte Nov 4, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
test for panic in handle_retrieve_transactions
  • Loading branch information
czarte committed Jul 19, 2024
commit c974b66ecb6e49e2c0e2d9f47b3352e788fd8084
38 changes: 13 additions & 25 deletions ip_country/src/country_finder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -166,11 +166,13 @@ mod tests {
)
.unwrap();

assert_eq!(result.free_world, true);
assert_eq!(result.iso3166, "US".to_string());
assert_eq!(result.name, "United States".to_string());
}

#[test]
fn real_test_ipv4_with_cz_isp() {
fn real_test_ipv4_with_cz_ip() {
let result = CountryCodeFinder::find_country(
&COUNTRY_CODE_FINDER,
IpAddr::from_str("77.75.77.222").unwrap(), // dig www.seznam.cz A
Expand All @@ -183,7 +185,7 @@ mod tests {
}

#[test]
fn real_test_ipv4_with_sk_isp() {
fn real_test_ipv4_with_sk_ip() {
let _ = CountryCodeFinder::find_country(
&COUNTRY_CODE_FINDER,
IpAddr::from_str("213.81.185.100").unwrap(), // dig www.zoznam.sk A
Expand Down Expand Up @@ -219,46 +221,32 @@ mod tests {
.unwrap();
let time_end = SystemTime::now();

assert_eq!(result.free_world, true);
assert_eq!(result.iso3166, "US".to_string());
assert_eq!(result.name, "United States".to_string());
let duration = time_end.duration_since(time_start).unwrap();
assert!(duration.as_secs() < 1, "Duration of the search was too long: {} ms", duration.as_millis());
}

#[test]
fn deserialize_country_blocks_ipv4_and_ipv6_adn_fill_vecs() {
let mut result_ipv4: Vec<CountryBlock> = vec![];
let mut result_ipv6: Vec<CountryBlock> = vec![];
let time_start = SystemTime::now();
let mut deserializer_ipv4 =
let deserializer_ipv4 =
CountryBlockDeserializerIpv4::new(crate::dbip_country::ipv4_country_data());
let mut deserializer_ipv6 =
let deserializer_ipv6 =
CountryBlockDeserializerIpv6::new(crate::dbip_country::ipv6_country_data());
let time_end = SystemTime::now();

let time_start_fill = SystemTime::now();
loop {
match deserializer_ipv4.next() {
None => break,
Some(country_block) => {
result_ipv4.push(country_block);
}
}
}
loop {
match deserializer_ipv6.next() {
None => break,
Some(country_block) => {
result_ipv6.push(country_block);
}
}
}
let _ = deserializer_ipv4.collect_vec();
let _ = deserializer_ipv6.collect_vec();
let time_end_fill = SystemTime::now();

let duration = time_end.duration_since(time_start).unwrap();
let duration_deserialize = time_end.duration_since(time_start).unwrap();
let duration_fill = time_end_fill
.duration_since(time_start_fill)
.unwrap();
assert!(duration.as_secs() < 5, "Duration of the deserialization was too long: {} ms", duration.as_millis());
assert!(duration_fill.as_secs() < 1, "Duration of the filling the vectors was too long: {} ms", duration_fill.as_millis());
assert!(duration_deserialize.as_secs() < 5, "Duration of the deserialization was too long: {} ms", duration_deserialize.as_millis());
assert!(duration_fill.as_secs() < 2, "Duration of the filling the vectors was too long: {} ms", duration_fill.as_millis());
}
}
34 changes: 34 additions & 0 deletions node/src/blockchain/blockchain_bridge.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1625,6 +1625,40 @@ mod tests {
let _ = subject.handle_retrieve_transactions(retrieve_transactions);
}

#[test]
#[should_panic(
expected = "Writing max_block_count failed: QueryFailed"
)]
fn handle_retrieve_transactions_panics_if_writing_max_block_count_failed() {
let retrieve_transactions_params_arc = Arc::new(Mutex::new(vec![]));
let earning_wallet = make_wallet("somewallet");
let latest_block_number = LatestBlockNumber::Ok(1024u64.into());
let lower_interface =
LowBlockchainIntMock::default().get_block_number_result(latest_block_number);
let blockchain_interface =
BlockchainInterfaceMock::default()
.retrieve_transactions_params(&retrieve_transactions_params_arc)
.retrieve_transactions_result(Err(BlockchainError::QueryFailed("RPC error: Error { code: ServerError(-32005), message: \"eth_getLogs is limited to 1024 block range. Please check the parameter requirements at https://docs.blockpi.io/documentations/api-reference\", data: None }".to_string())))
.lower_interface_results(Box::new(lower_interface));
let persistent_config = PersistentConfigurationMock::new()
.max_block_count_result(Ok(Some(10000u64)))
.start_block_result(Ok(6))
.set_max_block_count_result(Err(PersistentConfigError::TransactionError));
let mut subject = BlockchainBridge::new(
Box::new(blockchain_interface),
Box::new(persistent_config),
false,
Some(make_wallet("consuming")),
);

let retrieve_transactions = RetrieveTransactions {
recipient: earning_wallet,
response_skeleton_opt: None,
};

let _ = subject.handle_retrieve_transactions(retrieve_transactions);
}

fn success_handler(
_bcb: &mut BlockchainBridge,
_msg: RetrieveTransactions,
Expand Down