2017-08-04 23:14:17 +07:00
|
|
|
package console_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/robertkrimen/otto"
|
2018-06-08 13:29:50 +02:00
|
|
|
"github.com/status-im/status-go/jail/console"
|
2018-05-03 09:35:58 +02:00
|
|
|
"github.com/status-im/status-go/signal"
|
2017-08-04 23:14:17 +07:00
|
|
|
"github.com/stretchr/testify/suite"
|
|
|
|
)
|
|
|
|
|
|
|
|
// TestConsole validates the behaviour of giving conole extensions.
|
|
|
|
func TestConsole(t *testing.T) {
|
|
|
|
suite.Run(t, new(ConsoleTestSuite))
|
|
|
|
}
|
|
|
|
|
|
|
|
type ConsoleTestSuite struct {
|
|
|
|
suite.Suite
|
|
|
|
vm *otto.Otto
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *ConsoleTestSuite) SetupTest() {
|
|
|
|
require := s.Require()
|
|
|
|
|
|
|
|
vm := otto.New()
|
|
|
|
require.NotNil(vm)
|
|
|
|
s.vm = vm
|
|
|
|
}
|
|
|
|
|
|
|
|
// TestConsoleLog will validate the operations of the console.log extension
|
|
|
|
// for the otto vm.
|
|
|
|
func (s *ConsoleTestSuite) TestConsoleLog() {
|
|
|
|
require := s.Require()
|
|
|
|
written := "Bob Marley"
|
|
|
|
|
|
|
|
var customWriter bytes.Buffer
|
|
|
|
|
|
|
|
err := s.vm.Set("console", map[string]interface{}{
|
|
|
|
"log": func(fn otto.FunctionCall) otto.Value {
|
2018-05-03 09:35:58 +02:00
|
|
|
return console.Write(fn, &customWriter)
|
2017-08-04 23:14:17 +07:00
|
|
|
},
|
|
|
|
})
|
|
|
|
require.NoError(err)
|
|
|
|
|
|
|
|
_, err = s.vm.Run(fmt.Sprintf(`console.log(%q);`, written))
|
|
|
|
require.NoError(err)
|
|
|
|
require.Equal(written, strings.TrimPrefix(customWriter.String(), "vm.console: "))
|
|
|
|
}
|
|
|
|
|
|
|
|
// TestObjectLogging will validate the operations of the console.log extension
|
|
|
|
// when capturing objects declared from javascript.
|
|
|
|
func (s *ConsoleTestSuite) TestObjectLogging() {
|
|
|
|
require := s.Require()
|
|
|
|
|
|
|
|
var customWriter bytes.Buffer
|
|
|
|
|
2017-10-06 18:52:26 +02:00
|
|
|
signal.SetDefaultNodeNotificationHandler(func(event string) {
|
2017-08-04 23:14:17 +07:00
|
|
|
var eventReceived struct {
|
|
|
|
Type string `json:"type"`
|
|
|
|
Event []struct {
|
|
|
|
Age int `json:"age"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
} `json:"event"`
|
|
|
|
}
|
|
|
|
|
|
|
|
err := json.Unmarshal([]byte(event), &eventReceived)
|
|
|
|
require.NoError(err)
|
|
|
|
|
2018-05-03 09:35:58 +02:00
|
|
|
require.Equal(eventReceived.Type, signal.EventVMConsole)
|
2017-08-04 23:14:17 +07:00
|
|
|
require.NotEmpty(eventReceived.Event)
|
|
|
|
|
|
|
|
objectReceived := eventReceived.Event[0]
|
|
|
|
require.Equal(objectReceived.Age, 24)
|
|
|
|
require.Equal(objectReceived.Name, "bob")
|
|
|
|
})
|
|
|
|
|
|
|
|
err := s.vm.Set("console", map[string]interface{}{
|
|
|
|
"log": func(fn otto.FunctionCall) otto.Value {
|
2018-05-03 09:35:58 +02:00
|
|
|
return console.Write(fn, &customWriter)
|
2017-08-04 23:14:17 +07:00
|
|
|
},
|
|
|
|
})
|
|
|
|
require.NoError(err)
|
|
|
|
|
|
|
|
_, err = s.vm.Run(`
|
|
|
|
var person = {name:"bob", age:24}
|
|
|
|
console.log(person);
|
|
|
|
`)
|
|
|
|
require.NoError(err)
|
|
|
|
require.NotEmpty(&customWriter)
|
|
|
|
}
|