| 
									
										
										
										
											2018-02-14 13:49:11 +01:00
										 |  |  | // Copyright 2018 The go-ethereum Authors | 
					
						
							| 
									
										
										
										
											2018-01-16 15:42:41 +01:00
										 |  |  | // This file is part of go-ethereum. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // go-ethereum is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | // it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | // (at your option) any later version. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // go-ethereum 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 General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  | // along with go-ethereum. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package main | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"io/ioutil" | 
					
						
							|  |  |  | 	"os" | 
					
						
							|  |  |  | 	"path/filepath" | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestMessageSignVerify(t *testing.T) { | 
					
						
							|  |  |  | 	tmpdir, err := ioutil.TempDir("", "ethkey-test") | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		t.Fatal("Can't create temporary directory:", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	defer os.RemoveAll(tmpdir) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	keyfile := filepath.Join(tmpdir, "the-keyfile") | 
					
						
							|  |  |  | 	message := "test message" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Create the key. | 
					
						
							| 
									
										
										
										
											2020-02-17 12:22:52 +01:00
										 |  |  | 	generate := runEthkey(t, "generate", "--lightkdf", keyfile) | 
					
						
							| 
									
										
										
										
											2018-01-16 15:42:41 +01:00
										 |  |  | 	generate.Expect(` | 
					
						
							|  |  |  | !! Unsupported terminal, password will be echoed. | 
					
						
							| 
									
										
										
										
											2019-08-12 11:00:38 +02:00
										 |  |  | Password: {{.InputLine "foobar"}} | 
					
						
							|  |  |  | Repeat password: {{.InputLine "foobar"}} | 
					
						
							| 
									
										
										
										
											2018-01-16 15:42:41 +01:00
										 |  |  | `) | 
					
						
							|  |  |  | 	_, matches := generate.ExpectRegexp(`Address: (0x[0-9a-fA-F]{40})\n`) | 
					
						
							|  |  |  | 	address := matches[1] | 
					
						
							|  |  |  | 	generate.ExpectExit() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Sign a message. | 
					
						
							|  |  |  | 	sign := runEthkey(t, "signmessage", keyfile, message) | 
					
						
							|  |  |  | 	sign.Expect(` | 
					
						
							|  |  |  | !! Unsupported terminal, password will be echoed. | 
					
						
							| 
									
										
										
										
											2019-08-12 11:00:38 +02:00
										 |  |  | Password: {{.InputLine "foobar"}} | 
					
						
							| 
									
										
										
										
											2018-01-16 15:42:41 +01:00
										 |  |  | `) | 
					
						
							|  |  |  | 	_, matches = sign.ExpectRegexp(`Signature: ([0-9a-f]+)\n`) | 
					
						
							|  |  |  | 	signature := matches[1] | 
					
						
							|  |  |  | 	sign.ExpectExit() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Verify the message. | 
					
						
							|  |  |  | 	verify := runEthkey(t, "verifymessage", address, signature, message) | 
					
						
							|  |  |  | 	_, matches = verify.ExpectRegexp(` | 
					
						
							|  |  |  | Signature verification successful! | 
					
						
							|  |  |  | Recovered public key: [0-9a-f]+ | 
					
						
							|  |  |  | Recovered address: (0x[0-9a-fA-F]{40}) | 
					
						
							|  |  |  | `) | 
					
						
							|  |  |  | 	recovered := matches[1] | 
					
						
							|  |  |  | 	verify.ExpectExit() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if recovered != address { | 
					
						
							|  |  |  | 		t.Error("recovered address doesn't match generated key") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |