Enhance ledger-tool
Add a command-line argument (min-hashes) to restrict the entries processed by ledger-tool. For example, --min-hashes 1 will strip "empty" Entries, i.e. those with num_hashes = 0. Add basic ledger tool test
This commit is contained in:
		
				
					committed by
					
						 Greg Fitzgerald
						Greg Fitzgerald
					
				
			
			
				
	
			
			
			
						parent
						
							b26906df1b
						
					
				
				
					commit
					84cc240f34
				
			
							
								
								
									
										81
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										81
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -59,6 +59,17 @@ name = "ascii" | |||||||
| version = "0.7.1" | version = "0.7.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "assert_cmd" | ||||||
|  | version = "0.10.2" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "escargot 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "predicates 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "predicates-core 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "predicates-tree 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "atty" | name = "atty" | ||||||
| version = "0.2.11" | version = "0.2.11" | ||||||
| @@ -408,6 +419,11 @@ dependencies = [ | |||||||
|  "cfg-if 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "cfg-if 0.1.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "difference" | ||||||
|  | version = "2.0.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "digest" | name = "digest" | ||||||
| version = "0.7.6" | version = "0.7.6" | ||||||
| @@ -528,6 +544,15 @@ dependencies = [ | |||||||
|  "backtrace 0.3.13 (registry+https://github.com/rust-lang/crates.io-index)", |  "backtrace 0.3.13 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "escargot" | ||||||
|  | version = "0.3.1" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "serde 1.0.84 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "serde_json 1.0.34 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "failure" | name = "failure" | ||||||
| version = "0.1.3" | version = "0.1.3" | ||||||
| @@ -558,6 +583,14 @@ name = "feature-probe" | |||||||
| version = "0.1.1" | version = "0.1.1" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "float-cmp" | ||||||
|  | version = "0.4.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "num-traits 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "fnv" | name = "fnv" | ||||||
| version = "1.0.6" | version = "1.0.6" | ||||||
| @@ -1078,6 +1111,11 @@ dependencies = [ | |||||||
|  "memchr 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", |  "memchr 1.0.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "normalize-line-endings" | ||||||
|  | version = "0.2.2" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "num-integer" | name = "num-integer" | ||||||
| version = "0.1.39" | version = "0.1.39" | ||||||
| @@ -1247,6 +1285,32 @@ dependencies = [ | |||||||
|  "ws2_32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", |  "ws2_32-sys 0.2.1 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "predicates" | ||||||
|  | version = "1.0.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "difference 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "float-cmp 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "normalize-line-endings 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "predicates-core 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "regex 1.1.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "predicates-core" | ||||||
|  | version = "1.0.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "predicates-tree" | ||||||
|  | version = "1.0.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  | dependencies = [ | ||||||
|  |  "predicates-core 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "treeline 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pretty_env_logger" | name = "pretty_env_logger" | ||||||
| version = "0.2.5" | version = "0.2.5" | ||||||
| @@ -2024,10 +2088,13 @@ dependencies = [ | |||||||
| name = "solana-ledger-tool" | name = "solana-ledger-tool" | ||||||
| version = "0.12.0" | version = "0.12.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  |  "assert_cmd 0.10.2 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "clap 2.32.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "clap 2.32.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "predicates 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "serde_json 1.0.34 (registry+https://github.com/rust-lang/crates.io-index)", |  "serde_json 1.0.34 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "solana 0.12.0", |  "solana 0.12.0", | ||||||
|  "solana-logger 0.12.0", |  "solana-logger 0.12.0", | ||||||
|  |  "solana-sdk 0.12.0", | ||||||
| ] | ] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -2511,6 +2578,11 @@ name = "traitobject" | |||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| source = "registry+https://github.com/rust-lang/crates.io-index" | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "treeline" | ||||||
|  | version = "0.1.0" | ||||||
|  | source = "registry+https://github.com/rust-lang/crates.io-index" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "try-lock" | name = "try-lock" | ||||||
| version = "0.2.2" | version = "0.2.2" | ||||||
| @@ -2714,6 +2786,7 @@ dependencies = [ | |||||||
| "checksum arrayref 0.3.5 (registry+https://github.com/rust-lang/crates.io-index)" = "0d382e583f07208808f6b1249e60848879ba3543f57c32277bf52d69c2f0f0ee" | "checksum arrayref 0.3.5 (registry+https://github.com/rust-lang/crates.io-index)" = "0d382e583f07208808f6b1249e60848879ba3543f57c32277bf52d69c2f0f0ee" | ||||||
| "checksum arrayvec 0.4.9 (registry+https://github.com/rust-lang/crates.io-index)" = "d18513977c2d8261c448511c5c53dc66b26dfccbc3d4446672dea1e71a7d8a26" | "checksum arrayvec 0.4.9 (registry+https://github.com/rust-lang/crates.io-index)" = "d18513977c2d8261c448511c5c53dc66b26dfccbc3d4446672dea1e71a7d8a26" | ||||||
| "checksum ascii 0.7.1 (registry+https://github.com/rust-lang/crates.io-index)" = "3ae7d751998c189c1d4468cf0a39bb2eae052a9c58d50ebb3b9591ee3813ad50" | "checksum ascii 0.7.1 (registry+https://github.com/rust-lang/crates.io-index)" = "3ae7d751998c189c1d4468cf0a39bb2eae052a9c58d50ebb3b9591ee3813ad50" | ||||||
|  | "checksum assert_cmd 0.10.2 (registry+https://github.com/rust-lang/crates.io-index)" = "b7ac5c260f75e4e4ba87b7342be6edcecbcb3eb6741a0507fda7ad115845cc65" | ||||||
| "checksum atty 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)" = "9a7d5b8723950951411ee34d271d99dddcc2035a16ab25310ea2c8cfd4369652" | "checksum atty 0.2.11 (registry+https://github.com/rust-lang/crates.io-index)" = "9a7d5b8723950951411ee34d271d99dddcc2035a16ab25310ea2c8cfd4369652" | ||||||
| "checksum autocfg 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "4e5f34df7a019573fb8bdc7e24a2bfebe51a2a1d6bfdbaeccedb3c41fc574727" | "checksum autocfg 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "4e5f34df7a019573fb8bdc7e24a2bfebe51a2a1d6bfdbaeccedb3c41fc574727" | ||||||
| "checksum backtrace 0.3.13 (registry+https://github.com/rust-lang/crates.io-index)" = "b5b493b66e03090ebc4343eb02f94ff944e0cbc9ac6571491d170ba026741eb5" | "checksum backtrace 0.3.13 (registry+https://github.com/rust-lang/crates.io-index)" = "b5b493b66e03090ebc4343eb02f94ff944e0cbc9ac6571491d170ba026741eb5" | ||||||
| @@ -2755,6 +2828,7 @@ dependencies = [ | |||||||
| "checksum crossbeam-epoch 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)" = "f10a4f8f409aaac4b16a5474fb233624238fcdeefb9ba50d5ea059aab63ba31c" | "checksum crossbeam-epoch 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)" = "f10a4f8f409aaac4b16a5474fb233624238fcdeefb9ba50d5ea059aab63ba31c" | ||||||
| "checksum crossbeam-utils 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "2760899e32a1d58d5abb31129f8fae5de75220bc2176e77ff7c627ae45c918d9" | "checksum crossbeam-utils 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "2760899e32a1d58d5abb31129f8fae5de75220bc2176e77ff7c627ae45c918d9" | ||||||
| "checksum crossbeam-utils 0.6.3 (registry+https://github.com/rust-lang/crates.io-index)" = "41ee4864f4797060e52044376f7d107429ce1fb43460021b126424b7180ee21a" | "checksum crossbeam-utils 0.6.3 (registry+https://github.com/rust-lang/crates.io-index)" = "41ee4864f4797060e52044376f7d107429ce1fb43460021b126424b7180ee21a" | ||||||
|  | "checksum difference 2.0.0 (registry+https://github.com/rust-lang/crates.io-index)" = "524cbf6897b527295dff137cec09ecf3a05f4fddffd7dfcd1585403449e74198" | ||||||
| "checksum digest 0.7.6 (registry+https://github.com/rust-lang/crates.io-index)" = "03b072242a8cbaf9c145665af9d250c59af3b958f83ed6824e13533cf76d5b90" | "checksum digest 0.7.6 (registry+https://github.com/rust-lang/crates.io-index)" = "03b072242a8cbaf9c145665af9d250c59af3b958f83ed6824e13533cf76d5b90" | ||||||
| "checksum digest 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)" = "05f47366984d3ad862010e22c7ce81a7dbcaebbdfb37241a620f8b6596ee135c" | "checksum digest 0.8.0 (registry+https://github.com/rust-lang/crates.io-index)" = "05f47366984d3ad862010e22c7ce81a7dbcaebbdfb37241a620f8b6596ee135c" | ||||||
| "checksum dirs 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)" = "88972de891f6118092b643d85a0b28e0678e0f948d7f879aa32f2d5aafe97d2a" | "checksum dirs 1.0.4 (registry+https://github.com/rust-lang/crates.io-index)" = "88972de891f6118092b643d85a0b28e0678e0f948d7f879aa32f2d5aafe97d2a" | ||||||
| @@ -2767,10 +2841,12 @@ dependencies = [ | |||||||
| "checksum env_logger 0.5.13 (registry+https://github.com/rust-lang/crates.io-index)" = "15b0a4d2e39f8420210be8b27eeda28029729e2fd4291019455016c348240c38" | "checksum env_logger 0.5.13 (registry+https://github.com/rust-lang/crates.io-index)" = "15b0a4d2e39f8420210be8b27eeda28029729e2fd4291019455016c348240c38" | ||||||
| "checksum env_logger 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)" = "afb070faf94c85d17d50ca44f6ad076bce18ae92f0037d350947240a36e9d42e" | "checksum env_logger 0.6.0 (registry+https://github.com/rust-lang/crates.io-index)" = "afb070faf94c85d17d50ca44f6ad076bce18ae92f0037d350947240a36e9d42e" | ||||||
| "checksum error-chain 0.12.0 (registry+https://github.com/rust-lang/crates.io-index)" = "07e791d3be96241c77c43846b665ef1384606da2cd2a48730abe606a12906e02" | "checksum error-chain 0.12.0 (registry+https://github.com/rust-lang/crates.io-index)" = "07e791d3be96241c77c43846b665ef1384606da2cd2a48730abe606a12906e02" | ||||||
|  | "checksum escargot 0.3.1 (registry+https://github.com/rust-lang/crates.io-index)" = "19db1f7e74438642a5018cdf263bb1325b2e792f02dd0a3ca6d6c0f0d7b1d5a5" | ||||||
| "checksum failure 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "6dd377bcc1b1b7ce911967e3ec24fa19c3224394ec05b54aa7b083d498341ac7" | "checksum failure 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "6dd377bcc1b1b7ce911967e3ec24fa19c3224394ec05b54aa7b083d498341ac7" | ||||||
| "checksum failure_derive 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "64c2d913fe8ed3b6c6518eedf4538255b989945c14c2a7d5cbff62a5e2120596" | "checksum failure_derive 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "64c2d913fe8ed3b6c6518eedf4538255b989945c14c2a7d5cbff62a5e2120596" | ||||||
| "checksum fake-simd 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "e88a8acf291dafb59c2d96e8f59828f3838bb1a70398823ade51a84de6a6deed" | "checksum fake-simd 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "e88a8acf291dafb59c2d96e8f59828f3838bb1a70398823ade51a84de6a6deed" | ||||||
| "checksum feature-probe 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "835a3dc7d1ec9e75e2b5fb4ba75396837112d2060b03f7d43bc1897c7f7211da" | "checksum feature-probe 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "835a3dc7d1ec9e75e2b5fb4ba75396837112d2060b03f7d43bc1897c7f7211da" | ||||||
|  | "checksum float-cmp 0.4.0 (registry+https://github.com/rust-lang/crates.io-index)" = "134a8fa843d80a51a5b77d36d42bc2def9edcb0262c914861d08129fd1926600" | ||||||
| "checksum fnv 1.0.6 (registry+https://github.com/rust-lang/crates.io-index)" = "2fad85553e09a6f881f739c29f0b00b0f01357c743266d478b68951ce23285f3" | "checksum fnv 1.0.6 (registry+https://github.com/rust-lang/crates.io-index)" = "2fad85553e09a6f881f739c29f0b00b0f01357c743266d478b68951ce23285f3" | ||||||
| "checksum foreign-types 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)" = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" | "checksum foreign-types 0.3.2 (registry+https://github.com/rust-lang/crates.io-index)" = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1" | ||||||
| "checksum foreign-types-shared 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" | "checksum foreign-types-shared 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b" | ||||||
| @@ -2829,6 +2905,7 @@ dependencies = [ | |||||||
| "checksum nix 0.12.0 (registry+https://github.com/rust-lang/crates.io-index)" = "921f61dc817b379d0834e45d5ec45beaacfae97082090a49c2cf30dcbc30206f" | "checksum nix 0.12.0 (registry+https://github.com/rust-lang/crates.io-index)" = "921f61dc817b379d0834e45d5ec45beaacfae97082090a49c2cf30dcbc30206f" | ||||||
| "checksum nodrop 0.1.13 (registry+https://github.com/rust-lang/crates.io-index)" = "2f9667ddcc6cc8a43afc9b7917599d7216aa09c463919ea32c59ed6cac8bc945" | "checksum nodrop 0.1.13 (registry+https://github.com/rust-lang/crates.io-index)" = "2f9667ddcc6cc8a43afc9b7917599d7216aa09c463919ea32c59ed6cac8bc945" | ||||||
| "checksum nom 3.2.1 (registry+https://github.com/rust-lang/crates.io-index)" = "05aec50c70fd288702bcd93284a8444607f3292dbdf2a30de5ea5dcdbe72287b" | "checksum nom 3.2.1 (registry+https://github.com/rust-lang/crates.io-index)" = "05aec50c70fd288702bcd93284a8444607f3292dbdf2a30de5ea5dcdbe72287b" | ||||||
|  | "checksum normalize-line-endings 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "2e0a1a39eab95caf4f5556da9289b9e68f0aafac901b2ce80daaf020d3b733a8" | ||||||
| "checksum num-integer 0.1.39 (registry+https://github.com/rust-lang/crates.io-index)" = "e83d528d2677f0518c570baf2b7abdcf0cd2d248860b68507bdcb3e91d4c0cea" | "checksum num-integer 0.1.39 (registry+https://github.com/rust-lang/crates.io-index)" = "e83d528d2677f0518c570baf2b7abdcf0cd2d248860b68507bdcb3e91d4c0cea" | ||||||
| "checksum num-traits 0.1.43 (registry+https://github.com/rust-lang/crates.io-index)" = "92e5113e9fd4cc14ded8e499429f396a20f98c772a47cc8622a736e1ec843c31" | "checksum num-traits 0.1.43 (registry+https://github.com/rust-lang/crates.io-index)" = "92e5113e9fd4cc14ded8e499429f396a20f98c772a47cc8622a736e1ec843c31" | ||||||
| "checksum num-traits 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)" = "0b3a5d7cc97d6d30d8b9bc8fa19bf45349ffe46241e8816f50f62f6d6aaabee1" | "checksum num-traits 0.2.6 (registry+https://github.com/rust-lang/crates.io-index)" = "0b3a5d7cc97d6d30d8b9bc8fa19bf45349ffe46241e8816f50f62f6d6aaabee1" | ||||||
| @@ -2850,6 +2927,9 @@ dependencies = [ | |||||||
| "checksum pnet_base 0.21.0 (registry+https://github.com/rust-lang/crates.io-index)" = "948dbdd36f46888ada1d497703e6cae53d227ab0e8871638aba492ad1e4a76dc" | "checksum pnet_base 0.21.0 (registry+https://github.com/rust-lang/crates.io-index)" = "948dbdd36f46888ada1d497703e6cae53d227ab0e8871638aba492ad1e4a76dc" | ||||||
| "checksum pnet_datalink 0.21.0 (registry+https://github.com/rust-lang/crates.io-index)" = "f8d3b3dd76a11ad99d92fef54b2489f76f4045ebd5251bd1af485d55a7e13db6" | "checksum pnet_datalink 0.21.0 (registry+https://github.com/rust-lang/crates.io-index)" = "f8d3b3dd76a11ad99d92fef54b2489f76f4045ebd5251bd1af485d55a7e13db6" | ||||||
| "checksum pnet_sys 0.21.0 (registry+https://github.com/rust-lang/crates.io-index)" = "963b9109a05c3ac370abc3fda61bff20d03743c2947942173871b9cac2b9acb0" | "checksum pnet_sys 0.21.0 (registry+https://github.com/rust-lang/crates.io-index)" = "963b9109a05c3ac370abc3fda61bff20d03743c2947942173871b9cac2b9acb0" | ||||||
|  | "checksum predicates 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)" = "fa984b7cd021a0bf5315bcce4c4ae61d2a535db2a8d288fc7578638690a7b7c3" | ||||||
|  | "checksum predicates-core 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)" = "06075c3a3e92559ff8929e7a280684489ea27fe44805174c3ebd9328dcb37178" | ||||||
|  | "checksum predicates-tree 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)" = "8e63c4859013b38a76eca2414c64911fba30def9e3202ac461a2d22831220124" | ||||||
| "checksum pretty_env_logger 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)" = "ed8d1e63042e889b85228620629b51c011d380eed2c7e0015f8a644def280c28" | "checksum pretty_env_logger 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)" = "ed8d1e63042e889b85228620629b51c011d380eed2c7e0015f8a644def280c28" | ||||||
| "checksum proc-macro-hack 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)" = "2c725b36c99df7af7bf9324e9c999b9e37d92c8f8caf106d82e1d7953218d2d8" | "checksum proc-macro-hack 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)" = "2c725b36c99df7af7bf9324e9c999b9e37d92c8f8caf106d82e1d7953218d2d8" | ||||||
| "checksum proc-macro-hack-impl 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)" = "2b753ad9ed99dd8efeaa7d2fb8453c8f6bc3e54b97966d35f1bc77ca6865254a" | "checksum proc-macro-hack-impl 0.4.1 (registry+https://github.com/rust-lang/crates.io-index)" = "2b753ad9ed99dd8efeaa7d2fb8453c8f6bc3e54b97966d35f1bc77ca6865254a" | ||||||
| @@ -2943,6 +3023,7 @@ dependencies = [ | |||||||
| "checksum tokio-udp 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "66268575b80f4a4a710ef83d087fdfeeabdce9b74c797535fbac18a2cb906e92" | "checksum tokio-udp 0.1.3 (registry+https://github.com/rust-lang/crates.io-index)" = "66268575b80f4a4a710ef83d087fdfeeabdce9b74c797535fbac18a2cb906e92" | ||||||
| "checksum tokio-uds 0.2.4 (registry+https://github.com/rust-lang/crates.io-index)" = "99ce87382f6c1a24b513a72c048b2c8efe66cb5161c9061d00bee510f08dc168" | "checksum tokio-uds 0.2.4 (registry+https://github.com/rust-lang/crates.io-index)" = "99ce87382f6c1a24b513a72c048b2c8efe66cb5161c9061d00bee510f08dc168" | ||||||
| "checksum traitobject 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "efd1f82c56340fdf16f2a953d7bda4f8fdffba13d93b00844c25572110b26079" | "checksum traitobject 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "efd1f82c56340fdf16f2a953d7bda4f8fdffba13d93b00844c25572110b26079" | ||||||
|  | "checksum treeline 0.1.0 (registry+https://github.com/rust-lang/crates.io-index)" = "a7f741b240f1a48843f9b8e0444fb55fb2a4ff67293b50a9179dfd5ea67f8d41" | ||||||
| "checksum try-lock 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "e604eb7b43c06650e854be16a2a03155743d3752dd1c943f6829e26b7a36e382" | "checksum try-lock 0.2.2 (registry+https://github.com/rust-lang/crates.io-index)" = "e604eb7b43c06650e854be16a2a03155743d3752dd1c943f6829e26b7a36e382" | ||||||
| "checksum typeable 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "1410f6f91f21d1612654e7cc69193b0334f909dcf2c790c4826254fbb86f8887" | "checksum typeable 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "1410f6f91f21d1612654e7cc69193b0334f909dcf2c790c4826254fbb86f8887" | ||||||
| "checksum typenum 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)" = "612d636f949607bdf9b123b4a6f6d966dedf3ff669f7f045890d3a4a73948169" | "checksum typenum 1.10.0 (registry+https://github.com/rust-lang/crates.io-index)" = "612d636f949607bdf9b123b4a6f6d966dedf3ff669f7f045890d3a4a73948169" | ||||||
|   | |||||||
| @@ -11,7 +11,12 @@ homepage = "https://solana.com/" | |||||||
| clap = "2.32.0" | clap = "2.32.0" | ||||||
| serde_json = "1.0.34" | serde_json = "1.0.34" | ||||||
| solana = { path = "..", version = "0.12.0" } | solana = { path = "..", version = "0.12.0" } | ||||||
|  | solana-sdk = { path = "../sdk", version = "0.12.0" } | ||||||
| solana-logger = { path = "../logger", version = "0.12.0" } | solana-logger = { path = "../logger", version = "0.12.0" } | ||||||
|  |  | ||||||
|  | [dev-dependencies] | ||||||
|  | assert_cmd = "0.10" | ||||||
|  | predicates = "1" | ||||||
|  |  | ||||||
| [features] | [features] | ||||||
| cuda = [] | cuda = [] | ||||||
|   | |||||||
| @@ -25,6 +25,14 @@ fn main() { | |||||||
|                 .takes_value(true) |                 .takes_value(true) | ||||||
|                 .help("Limit to at most the first NUM entries in ledger\n  (only applies to verify, print, json commands)"), |                 .help("Limit to at most the first NUM entries in ledger\n  (only applies to verify, print, json commands)"), | ||||||
|         ) |         ) | ||||||
|  |         .arg( | ||||||
|  |             Arg::with_name("min-hashes") | ||||||
|  |                 .short("h") | ||||||
|  |                 .long("min-hashes") | ||||||
|  |                 .value_name("NUM") | ||||||
|  |                 .takes_value(true) | ||||||
|  |                 .help("Skip entries with fewer than NUM hashes\n  (only applies to print and json commands)"), | ||||||
|  |         ) | ||||||
|         .arg( |         .arg( | ||||||
|             Arg::with_name("precheck") |             Arg::with_name("precheck") | ||||||
|                 .short("p") |                 .short("p") | ||||||
| @@ -64,6 +72,13 @@ fn main() { | |||||||
|         None => <usize>::max_value(), |         None => <usize>::max_value(), | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  |     let min_hashes = match matches.value_of("min-hashes") { | ||||||
|  |         Some(hashes) => hashes | ||||||
|  |             .parse() | ||||||
|  |             .expect("please pass a number for --min-hashes"), | ||||||
|  |         None => 0, | ||||||
|  |     } as u64; | ||||||
|  |  | ||||||
|     match matches.subcommand() { |     match matches.subcommand() { | ||||||
|         ("print", _) => { |         ("print", _) => { | ||||||
|             let entries = match read_ledger(ledger_path, true) { |             let entries = match read_ledger(ledger_path, true) { | ||||||
| @@ -78,6 +93,9 @@ fn main() { | |||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 let entry = entry.unwrap(); |                 let entry = entry.unwrap(); | ||||||
|  |                 if entry.num_hashes < min_hashes { | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|                 println!("{:?}", entry); |                 println!("{:?}", entry); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -88,6 +106,9 @@ fn main() { | |||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|                 let entry = entry.unwrap(); |                 let entry = entry.unwrap(); | ||||||
|  |                 if entry.num_hashes < min_hashes { | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|                 serde_json::to_writer(stdout(), &entry).expect("serialize"); |                 serde_json::to_writer(stdout(), &entry).expect("serialize"); | ||||||
|                 stdout().write_all(b",\n").expect("newline"); |                 stdout().write_all(b",\n").expect("newline"); | ||||||
|             } |             } | ||||||
|   | |||||||
							
								
								
									
										57
									
								
								ledger-tool/tests/basic.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								ledger-tool/tests/basic.rs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | use solana::ledger::create_tmp_sample_ledger; | ||||||
|  | use solana_sdk::signature::{Keypair, KeypairUtil}; | ||||||
|  |  | ||||||
|  | use assert_cmd::prelude::*; | ||||||
|  | use std::process::Command; | ||||||
|  | use std::process::Output; | ||||||
|  | use std::sync::Arc; | ||||||
|  |  | ||||||
|  | fn run_ledger_tool(args: &[&str]) -> Output { | ||||||
|  |     Command::main_binary().unwrap().args(args).output().unwrap() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | fn count_newlines(chars: &[u8]) -> usize { | ||||||
|  |     chars.iter().filter(|&c| *c == '\n' as u8).count() | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #[test] | ||||||
|  | fn bad_arguments() { | ||||||
|  |     // At least a ledger path is required | ||||||
|  |     assert!(!run_ledger_tool(&[]).status.success()); | ||||||
|  |  | ||||||
|  |     // Invalid ledger path should fail | ||||||
|  |     assert!(!run_ledger_tool(&["-l", "invalid_ledger", "verify"]) | ||||||
|  |         .status | ||||||
|  |         .success()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #[test] | ||||||
|  | fn nominal() { | ||||||
|  |     let keypair = Arc::new(Keypair::new()); | ||||||
|  |     let (_mint, ledger_path, _genesis_entries) = | ||||||
|  |         create_tmp_sample_ledger("test_ledger_tool_nominal", 100, 10, keypair.pubkey(), 50); | ||||||
|  |  | ||||||
|  |     // Basic validation | ||||||
|  |     let output = run_ledger_tool(&["-l", &ledger_path, "verify"]); | ||||||
|  |     assert!(output.status.success()); | ||||||
|  |  | ||||||
|  |     // Print everything | ||||||
|  |     let output = run_ledger_tool(&["-l", &ledger_path, "print"]); | ||||||
|  |     assert!(output.status.success()); | ||||||
|  |     assert_eq!(count_newlines(&output.stdout), 13); | ||||||
|  |  | ||||||
|  |     // Only print the first 5 items | ||||||
|  |     let output = run_ledger_tool(&["-l", &ledger_path, "-n", "5", "print"]); | ||||||
|  |     assert!(output.status.success()); | ||||||
|  |     assert_eq!(count_newlines(&output.stdout), 5); | ||||||
|  |  | ||||||
|  |     // Skip entries with no hashes (first entry) | ||||||
|  |     let output = run_ledger_tool(&["-l", &ledger_path, "-h", "1", "print"]); | ||||||
|  |     assert!(output.status.success()); | ||||||
|  |     assert_eq!(count_newlines(&output.stdout), 12); | ||||||
|  |  | ||||||
|  |     // Skip entries with fewer than 2 hashes (skip everything) | ||||||
|  |     let output = run_ledger_tool(&["-l", &ledger_path, "-h", "2", "print"]); | ||||||
|  |     assert!(output.status.success()); | ||||||
|  |     assert_eq!(count_newlines(&output.stdout), 0); | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user