2015-07-06 19:54:22 -05:00
// Copyright 2015 The go-ethereum Authors
2015-07-22 11:48:40 -05:00
// This file is part of the go-ethereum library.
2015-07-06 19:54:22 -05:00
//
2015-07-23 11:35:11 -05:00
// The go-ethereum library is free software: you can redistribute it and/or modify
2015-07-06 19:54:22 -05:00
// 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.
//
2015-07-22 11:48:40 -05:00
// The go-ethereum library is distributed in the hope that it will be useful,
2015-07-06 19:54:22 -05:00
// but WITHOUT ANY WARRANTY; without even the implied warranty of
2015-07-22 11:48:40 -05:00
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2015-07-06 19:54:22 -05:00
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
2015-07-22 11:48:40 -05:00
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
2015-07-06 19:54:22 -05:00
2015-04-22 17:11:11 -05:00
package compiler
import (
"encoding/json"
"io/ioutil"
"os"
2015-08-06 09:19:09 -05:00
"path"
2015-04-22 17:11:11 -05:00
"testing"
"github.com/ethereum/go-ethereum/common"
)
2016-06-14 17:36:31 -05:00
const (
supportedSolcVersion = "0.3.5"
testSource = `
2015-04-22 17:11:11 -05:00
contract test {
/// @notice Will multiply ` + "`a`" + ` by 7.
function multiply ( uint a ) returns ( uint d ) {
return a * 7 ;
}
}
`
2016-06-14 17:36:31 -05:00
testCode = "0x6060604052602a8060106000396000f3606060405260e060020a6000350463c6888fa18114601a575b005b6007600435026060908152602090f3"
testInfo = ` { "source":"\ncontract test { \n /// @notice Will multiply ` + "`a`" + ` by 7.\n function multiply(uint a) returns(uint d) { \n return a * 7;\n }\n}\n","language":"Solidity","languageVersion":"0.1.1","compilerVersion":"0.1.1","compilerOptions":"--binary file --json-abi file --natspec-user file --natspec-dev file --add-std 1","abiDefinition":[ { "constant":false,"inputs":[ { "name":"a","type":"uint256"}],"name":"multiply","outputs":[ { "name":"d","type":"uint256"}],"type":"function"}],"userDoc": { "methods": { "multiply(uint256)": { "notice":"Will multiply ` + "`a`" + ` by 7."}}},"developerDoc": { "methods": { }}} `
2015-04-22 17:11:11 -05:00
)
2016-06-14 17:36:31 -05:00
func skipUnsupported ( t * testing . T ) {
sol , err := SolidityVersion ( "" )
2015-04-22 17:11:11 -05:00
if err != nil {
2016-06-14 17:36:31 -05:00
t . Skip ( err )
2015-04-22 17:11:11 -05:00
return
}
2016-06-14 17:36:31 -05:00
if sol . Version != supportedSolcVersion {
t . Skipf ( "unsupported version of solc found (%v, expect %v)" , sol . Version , supportedSolcVersion )
}
}
2015-05-18 09:31:26 -05:00
2016-06-14 17:36:31 -05:00
func TestCompiler ( t * testing . T ) {
skipUnsupported ( t )
contracts , err := CompileSolidityString ( "" , testSource )
if err != nil {
t . Fatalf ( "error compiling source. result %v: %v" , contracts , err )
}
2015-05-19 22:11:48 -05:00
if len ( contracts ) != 1 {
2016-04-15 04:06:57 -05:00
t . Errorf ( "one contract expected, got %d" , len ( contracts ) )
2015-05-19 22:11:48 -05:00
}
2016-06-14 17:36:31 -05:00
c , ok := contracts [ "test" ]
if ! ok {
t . Fatal ( "info for contract 'test' not present in result" )
}
if c . Code != testCode {
t . Errorf ( "wrong code: expected\n%s, got\n%s" , testCode , c . Code )
}
if c . Info . Source != testSource {
t . Error ( "wrong source" )
}
if c . Info . CompilerVersion != supportedSolcVersion {
t . Errorf ( "wrong version: expected %q, got %q" , supportedSolcVersion , c . Info . CompilerVersion )
2015-05-18 09:31:26 -05:00
}
2015-04-22 17:11:11 -05:00
}
func TestCompileError ( t * testing . T ) {
2016-06-14 17:36:31 -05:00
skipUnsupported ( t )
contracts , err := CompileSolidityString ( "" , testSource [ 4 : ] )
2015-04-22 17:11:11 -05:00
if err == nil {
2015-05-19 22:11:48 -05:00
t . Errorf ( "error expected compiling source. got none. result %v" , contracts )
2015-04-22 17:11:11 -05:00
}
2016-06-14 17:36:31 -05:00
t . Logf ( "error: %v" , err )
2015-04-22 17:11:11 -05:00
}
2015-06-23 09:48:33 -05:00
func TestSaveInfo ( t * testing . T ) {
2015-04-22 17:11:11 -05:00
var cinfo ContractInfo
2016-06-14 17:36:31 -05:00
err := json . Unmarshal ( [ ] byte ( testInfo ) , & cinfo )
2015-04-22 17:11:11 -05:00
if err != nil {
t . Errorf ( "%v" , err )
}
2015-08-06 09:19:09 -05:00
filename := path . Join ( os . TempDir ( ) , "solctest.info.json" )
2015-04-22 17:11:11 -05:00
os . Remove ( filename )
2015-06-23 09:48:33 -05:00
cinfohash , err := SaveInfo ( & cinfo , filename )
2015-04-22 17:11:11 -05:00
if err != nil {
2015-05-18 09:31:26 -05:00
t . Errorf ( "error extracting info: %v" , err )
2015-04-22 17:11:11 -05:00
}
got , err := ioutil . ReadFile ( filename )
if err != nil {
2015-05-18 09:31:26 -05:00
t . Errorf ( "error reading '%v': %v" , filename , err )
2015-04-22 17:11:11 -05:00
}
2016-06-14 17:36:31 -05:00
if string ( got ) != testInfo {
t . Errorf ( "incorrect info.json extracted, expected:\n%s\ngot\n%s" , testInfo , string ( got ) )
2015-04-22 17:11:11 -05:00
}
2016-06-14 17:36:31 -05:00
wantHash := common . HexToHash ( "0x9f3803735e7f16120c5a140ab3f02121fd3533a9655c69b33a10e78752cc49b0" )
if cinfohash != wantHash {
t . Errorf ( "content hash for info is incorrect. expected %v, got %v" , wantHash . Hex ( ) , cinfohash . Hex ( ) )
2015-04-22 17:11:11 -05:00
}
2015-09-10 07:12:41 -05:00
}