Skip to content

Commit

Permalink
common/compiler, common/docserver, jsre: fix tests on windows
Browse files Browse the repository at this point in the history
  • Loading branch information
fjl committed Aug 6, 2015
1 parent eae1191 commit 3832019
Show file tree
Hide file tree
Showing 4 changed files with 38 additions and 17 deletions.
5 changes: 3 additions & 2 deletions common/compiler/solidity_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import (
"encoding/json"
"io/ioutil"
"os"
"path"
"testing"

"github.com/ethereum/go-ethereum/common"
Expand Down Expand Up @@ -94,7 +95,7 @@ func TestSaveInfo(t *testing.T) {
if err != nil {
t.Errorf("%v", err)
}
filename := "/tmp/solctest.info.json"
filename := path.Join(os.TempDir(), "solctest.info.json")
os.Remove(filename)
cinfohash, err := SaveInfo(&cinfo, filename)
if err != nil {
Expand All @@ -110,4 +111,4 @@ func TestSaveInfo(t *testing.T) {
if cinfohash != infohash {
t.Errorf("content hash for info is incorrect. expected %v, got %v", infohash.Hex(), cinfohash.Hex())
}
}
}
1 change: 0 additions & 1 deletion common/docserver/docserver.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@ func New(docRoot string) (self *DocServer) {
DocRoot: docRoot,
schemes: []string{"file"},
}
self.DocRoot = "/tmp/"
self.RegisterProtocol("file", http.NewFileTransport(http.Dir(self.DocRoot)))
return
}
Expand Down
19 changes: 13 additions & 6 deletions common/docserver/docserver_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,19 +20,26 @@ import (
"io/ioutil"
"net/http"
"os"
"path"
"testing"

"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/crypto"
)

func TestGetAuthContent(t *testing.T) {
text := "test"
hash := common.Hash{}
copy(hash[:], crypto.Sha3([]byte(text)))
ioutil.WriteFile("/tmp/test.content", []byte(text), os.ModePerm)
dir, err := ioutil.TempDir("", "docserver-test")
if err != nil {
t.Fatal("cannot create temporary directory:", err)
}
defer os.RemoveAll(dir)
ds := New(dir)

ds := New("/tmp/")
text := "test"
hash := crypto.Sha3Hash([]byte(text))
if err := ioutil.WriteFile(path.Join(dir, "test.content"), []byte(text), os.ModePerm); err != nil {
t.Fatal("could not write test file", err)
}
content, err := ds.GetAuthContent("file:///test.content", hash)
if err != nil {
t.Errorf("no error expected, got %v", err)
Expand Down Expand Up @@ -67,4 +74,4 @@ func TestRegisterScheme(t *testing.T) {
if !ds.HasScheme("scheme") {
t.Errorf("expected scheme to be registered")
}
}
}
30 changes: 22 additions & 8 deletions jsre/jsre_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ package jsre
import (
"io/ioutil"
"os"
"path"
"testing"
"time"

Expand All @@ -40,10 +41,23 @@ func (no *testNativeObjectBinding) TestMethod(call otto.FunctionCall) otto.Value
return v
}

func newWithTestJS(t *testing.T, testjs string) (*JSRE, string) {
dir, err := ioutil.TempDir("", "jsre-test")
if err != nil {
t.Fatal("cannot create temporary directory:", err)
}
if testjs != "" {
if err := ioutil.WriteFile(path.Join(dir, "test.js"), []byte(testjs), os.ModePerm); err != nil {
t.Fatal("cannot create test.js:", err)
}
}
return New(dir), dir
}

func TestExec(t *testing.T) {
jsre := New("/tmp")
jsre, dir := newWithTestJS(t, `msg = "testMsg"`)
defer os.RemoveAll(dir)

ioutil.WriteFile("/tmp/test.js", []byte(`msg = "testMsg"`), os.ModePerm)
err := jsre.Exec("test.js")
if err != nil {
t.Errorf("expected no error, got %v", err)
Expand All @@ -64,9 +78,9 @@ func TestExec(t *testing.T) {
}

func TestNatto(t *testing.T) {
jsre := New("/tmp")
jsre, dir := newWithTestJS(t, `setTimeout(function(){msg = "testMsg"}, 1);`)
defer os.RemoveAll(dir)

ioutil.WriteFile("/tmp/test.js", []byte(`setTimeout(function(){msg = "testMsg"}, 1);`), os.ModePerm)
err := jsre.Exec("test.js")
if err != nil {
t.Errorf("expected no error, got %v", err)
Expand All @@ -88,7 +102,7 @@ func TestNatto(t *testing.T) {
}

func TestBind(t *testing.T) {
jsre := New("/tmp")
jsre := New("")

jsre.Bind("no", &testNativeObjectBinding{})

Expand All @@ -105,9 +119,9 @@ func TestBind(t *testing.T) {
}

func TestLoadScript(t *testing.T) {
jsre := New("/tmp")
jsre, dir := newWithTestJS(t, `msg = "testMsg"`)
defer os.RemoveAll(dir)

ioutil.WriteFile("/tmp/test.js", []byte(`msg = "testMsg"`), os.ModePerm)
_, err := jsre.Run(`loadScript("test.js")`)
if err != nil {
t.Errorf("expected no error, got %v", err)
Expand All @@ -125,4 +139,4 @@ func TestLoadScript(t *testing.T) {
t.Errorf("expected '%v', got '%v'", exp, got)
}
jsre.Stop(false)
}
}

0 comments on commit 3832019

Please sign in to comment.