| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | // Copyright 2017 The go-ethereum Authors | 
					
						
							|  |  |  | // This file is part of the go-ethereum library. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // The go-ethereum library is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | // it under the terms of the GNU Lesser General Public License as published by | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | // (at your option) any later version. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // The go-ethereum library is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 
					
						
							|  |  |  | // GNU Lesser General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU Lesser General Public License | 
					
						
							|  |  |  | // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package bitutil | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-23 17:44:45 +01:00
										 |  |  | import ( | 
					
						
							|  |  |  | 	"bytes" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/ethereum/go-ethereum/common/bitutil" | 
					
						
							|  |  |  | ) | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-08 10:40:48 +03:00
										 |  |  | // Fuzz implements a go-fuzz fuzzer method to test various encoding method | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | // invocations. | 
					
						
							|  |  |  | func Fuzz(data []byte) int { | 
					
						
							|  |  |  | 	if len(data) == 0 { | 
					
						
							| 
									
										
										
										
											2020-11-13 12:36:38 +01:00
										 |  |  | 		return 0 | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	if data[0]%2 == 0 { | 
					
						
							| 
									
										
										
										
											2017-05-08 10:40:48 +03:00
										 |  |  | 		return fuzzEncode(data[1:]) | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-05-08 10:40:48 +03:00
										 |  |  | 	return fuzzDecode(data[1:]) | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-08 10:40:48 +03:00
										 |  |  | // fuzzEncode implements a go-fuzz fuzzer method to test the bitset encoding and | 
					
						
							|  |  |  | // decoding algorithm. | 
					
						
							|  |  |  | func fuzzEncode(data []byte) int { | 
					
						
							| 
									
										
										
										
											2020-12-23 17:44:45 +01:00
										 |  |  | 	proc, _ := bitutil.DecompressBytes(bitutil.CompressBytes(data), len(data)) | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | 	if !bytes.Equal(data, proc) { | 
					
						
							|  |  |  | 		panic("content mismatch") | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-11-13 12:36:38 +01:00
										 |  |  | 	return 1 | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-08 10:40:48 +03:00
										 |  |  | // fuzzDecode implements a go-fuzz fuzzer method to test the bit decoding and | 
					
						
							|  |  |  | // reencoding algorithm. | 
					
						
							|  |  |  | func fuzzDecode(data []byte) int { | 
					
						
							| 
									
										
										
										
											2020-12-23 17:44:45 +01:00
										 |  |  | 	blob, err := bitutil.DecompressBytes(data, 1024) | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return 0 | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-12-27 21:58:39 +01:00
										 |  |  | 	// re-compress it (it's OK if the re-compressed differs from the | 
					
						
							|  |  |  | 	// original - the first input may not have been compressed at all) | 
					
						
							|  |  |  | 	comp := bitutil.CompressBytes(blob) | 
					
						
							|  |  |  | 	if len(comp) > len(blob) { | 
					
						
							|  |  |  | 		// After compression, it must be smaller or equal | 
					
						
							|  |  |  | 		panic("bad compression") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	// But decompressing it once again should work | 
					
						
							|  |  |  | 	decomp, err := bitutil.DecompressBytes(data, 1024) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		panic(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if !bytes.Equal(decomp, blob) { | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | 		panic("content mismatch") | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-11-13 12:36:38 +01:00
										 |  |  | 	return 1 | 
					
						
							| 
									
										
										
										
											2017-05-06 18:35:59 +03:00
										 |  |  | } |