2015-03-31 15:02:35 +00:00
|
|
|
package docserver
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
2015-06-23 14:48:33 +00:00
|
|
|
"net/http"
|
2015-03-31 15:02:35 +00:00
|
|
|
"os"
|
|
|
|
"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)
|
|
|
|
|
2015-06-23 14:48:33 +00:00
|
|
|
ds := New("/tmp/")
|
2015-03-31 15:02:35 +00:00
|
|
|
content, err := ds.GetAuthContent("file:///test.content", hash)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("no error expected, got %v", err)
|
|
|
|
}
|
|
|
|
if string(content) != text {
|
|
|
|
t.Errorf("incorrect content. expected %v, got %v", text, string(content))
|
|
|
|
}
|
|
|
|
|
|
|
|
hash = common.Hash{}
|
|
|
|
content, err = ds.GetAuthContent("file:///test.content", hash)
|
|
|
|
expected := "content hash mismatch"
|
|
|
|
if err == nil {
|
|
|
|
t.Errorf("expected error, got nothing")
|
|
|
|
} else {
|
|
|
|
if err.Error() != expected {
|
|
|
|
t.Errorf("expected error '%s' got '%v'", expected, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2015-06-23 14:48:33 +00:00
|
|
|
|
|
|
|
type rt struct{}
|
|
|
|
|
|
|
|
func (rt) RoundTrip(req *http.Request) (resp *http.Response, err error) { return }
|
|
|
|
|
|
|
|
func TestRegisterScheme(t *testing.T) {
|
|
|
|
ds := New("/tmp/")
|
|
|
|
if ds.HasScheme("scheme") {
|
|
|
|
t.Errorf("expected scheme not to be registered")
|
|
|
|
}
|
|
|
|
ds.RegisterScheme("scheme", rt{})
|
|
|
|
if !ds.HasScheme("scheme") {
|
|
|
|
t.Errorf("expected scheme to be registered")
|
|
|
|
}
|
|
|
|
}
|