Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
N
neo
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
2
Merge Requests
2
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Jobs
Commits
Open sidebar
Kirill Smelkov
neo
Commits
60a44061
Commit
60a44061
authored
Dec 16, 2020
by
Kirill Smelkov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
.
parent
a2f192cb
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
117 additions
and
50 deletions
+117
-50
go/neo/client_test.go
go/neo/client_test.go
+117
-50
No files found.
go/neo/client_test.go
View file @
60a44061
...
@@ -46,14 +46,26 @@ type NEOSrv interface {
...
@@ -46,14 +46,26 @@ type NEOSrv interface {
Bugs
()
[]
string
// list of known server bugs
Bugs
()
[]
string
// list of known server bugs
}
}
// NEOSrvOptions represents options for a NEO server.
type
NEOSrvOptions
struct
{
workdir
string
// location for database and log files
name
string
// name of the cluster
// nmaster
// npartition
// nreplica
SSL
bool
// whether to use SSL for node-node exchange
}
// ---- NEO/py ----
// NEOPySrv represents running NEO/py server.
// NEOPySrv represents running NEO/py server.
//
//
// Create it with StartNEOPySrv
(XXX)
.
// Create it with StartNEOPySrv.
type
NEOPySrv
struct
{
type
NEOPySrv
struct
{
pysrv
*
xexec
.
Cmd
// spawned `runneo.py`
pysrv
*
xexec
.
Cmd
// spawned `runneo.py`
workdir
string
// location for database and log files
opt
NEOSrvOptions
// options for spawned server
clusterName
string
// name of the cluster
opt
NEOPyOptions
// options for spawned server
cancel
func
()
// to stop pysrv
cancel
func
()
// to stop pysrv
done
chan
struct
{}
// ready after Wait completes
done
chan
struct
{}
// ready after Wait completes
errExit
error
// error from Wait
errExit
error
// error from Wait
...
@@ -67,25 +79,14 @@ type NEOPySrv struct {
...
@@ -67,25 +79,14 @@ type NEOPySrv struct {
}
}
func
(
_
*
NEOPySrv
)
Bugs
()
[]
string
{
func
(
_
*
NEOPySrv
)
Bugs
()
[]
string
{
return
[]
string
{
return
[]
string
{}
// XXX
}
}
}
type
NEOPyOptions
struct
{
// StartNEOPySrv starts NEO/py server specified by options.
// nmaster
// npartition
// nreplica
// name
SSL
bool
// whether to use SSL for node-node exchange
}
// StartNEOPySrv starts NEO/py server for clusterName NEO database located in workdir/.
// XXX dup wrt zeo?
// XXX dup wrt zeo?
func
StartNEOPySrv
(
workdir
,
clusterName
string
,
opt
NEOPyOptions
)
(
_
*
NEOPySrv
,
err
error
)
{
func
StartNEOPySrv
(
opt
NEOSrvOptions
)
(
_
*
NEOPySrv
,
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"startneo %s/%s"
,
workdir
,
clusterName
)
workdir
:=
opt
.
workdir
defer
xerr
.
Contextf
(
&
err
,
"start neo/py %s/%s"
,
workdir
,
opt
.
name
)
ctx
,
cancel
:=
context
.
WithCancel
(
context
.
Background
())
ctx
,
cancel
:=
context
.
WithCancel
(
context
.
Background
())
...
@@ -98,7 +99,7 @@ func StartNEOPySrv(workdir, clusterName string, opt NEOPyOptions) (_ *NEOPySrv,
...
@@ -98,7 +99,7 @@ func StartNEOPySrv(workdir, clusterName string, opt NEOPyOptions) (_ *NEOPySrv,
return
nil
,
err
return
nil
,
err
}
}
n
:=
&
NEOPySrv
{
workdir
:
workdir
,
clusterName
:
clusterName
,
cancel
:
cancel
,
done
:
make
(
chan
struct
{})}
n
:=
&
NEOPySrv
{
opt
:
opt
,
cancel
:
cancel
,
done
:
make
(
chan
struct
{})}
if
opt
.
SSL
{
if
opt
.
SSL
{
npytests
:=
"../../neo/tests/"
npytests
:=
"../../neo/tests/"
n
.
CA
=
npytests
+
"ca.crt"
n
.
CA
=
npytests
+
"ca.crt"
...
@@ -107,13 +108,12 @@ func StartNEOPySrv(workdir, clusterName string, opt NEOPyOptions) (_ *NEOPySrv,
...
@@ -107,13 +108,12 @@ func StartNEOPySrv(workdir, clusterName string, opt NEOPyOptions) (_ *NEOPySrv,
}
}
// XXX $PYTHONPATH to top, so that `import neo` works?
// XXX $PYTHONPATH to top, so that `import neo` works?
n
.
pysrv
=
xexec
.
Command
(
"./py/runneo.py"
,
workdir
,
clusterN
ame
)
n
.
pysrv
=
xexec
.
Command
(
"./py/runneo.py"
,
workdir
,
opt
.
n
ame
)
if
opt
.
SSL
{
if
opt
.
SSL
{
n
.
pysrv
.
Args
=
append
(
n
.
pysrv
.
Args
,
"ca="
+
n
.
CA
)
n
.
pysrv
.
Args
=
append
(
n
.
pysrv
.
Args
,
"ca="
+
n
.
CA
)
n
.
pysrv
.
Args
=
append
(
n
.
pysrv
.
Args
,
"cert="
+
n
.
Cert
)
n
.
pysrv
.
Args
=
append
(
n
.
pysrv
.
Args
,
"cert="
+
n
.
Cert
)
n
.
pysrv
.
Args
=
append
(
n
.
pysrv
.
Args
,
"key="
+
n
.
Key
)
n
.
pysrv
.
Args
=
append
(
n
.
pysrv
.
Args
,
"key="
+
n
.
Key
)
}
}
n
.
opt
=
opt
// $TEMP -> workdir (else NEO/py creates another one for e.g. coverage)
// $TEMP -> workdir (else NEO/py creates another one for e.g. coverage)
n
.
pysrv
.
Env
=
append
(
os
.
Environ
(),
"TEMP="
+
workdir
)
n
.
pysrv
.
Env
=
append
(
os
.
Environ
(),
"TEMP="
+
workdir
)
n
.
pysrv
.
Stdin
=
nil
n
.
pysrv
.
Stdin
=
nil
...
@@ -166,7 +166,7 @@ func StartNEOPySrv(workdir, clusterName string, opt NEOPyOptions) (_ *NEOPySrv,
...
@@ -166,7 +166,7 @@ func StartNEOPySrv(workdir, clusterName string, opt NEOPyOptions) (_ *NEOPySrv,
}
}
func
(
n
*
NEOPySrv
)
ClusterName
()
string
{
func
(
n
*
NEOPySrv
)
ClusterName
()
string
{
return
n
.
clusterN
ame
return
n
.
opt
.
n
ame
}
}
func
(
n
*
NEOPySrv
)
MasterAddr
()
string
{
func
(
n
*
NEOPySrv
)
MasterAddr
()
string
{
...
@@ -190,7 +190,7 @@ func (n *NEOPySrv) ZUrl() string {
...
@@ -190,7 +190,7 @@ func (n *NEOPySrv) ZUrl() string {
}
}
func
(
n
*
NEOPySrv
)
Close
()
(
err
error
)
{
func
(
n
*
NEOPySrv
)
Close
()
(
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"stop
neo %s"
,
n
.
workdir
)
defer
xerr
.
Contextf
(
&
err
,
"stop
neo/py %s"
,
n
.
opt
.
workdir
)
n
.
cancel
()
n
.
cancel
()
<-
n
.
done
<-
n
.
done
...
@@ -201,6 +201,37 @@ func (n *NEOPySrv) Close() (err error) {
...
@@ -201,6 +201,37 @@ func (n *NEOPySrv) Close() (err error) {
return
err
return
err
}
}
// ---- NEO/go ----
// NEOGoSrv represents running NEO/go server.
//
// Create it with StartNEOGoSrv.
type
NEOGoSrv
struct
{
// XXX
opt
NEOSrvOptions
// server options
}
func
(
_
*
NEOGoSrv
)
Bugs
()
[]
string
{
return
[]
string
{
"nocommit"
}
}
// StartNEOGoSrv starts NEO/go server specified by options.
func
StartNEOGoSrv
(
opt
NEOSrvOptions
)
(
_
*
NEOGoSrv
,
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"start neo/go %s/%s"
,
opt
.
workdir
,
opt
.
name
)
return
nil
,
fmt
.
Errorf
(
"TODO"
)
}
func
(
n
*
NEOGoSrv
)
Close
()
(
err
error
)
{
defer
xerr
.
Contextf
(
&
err
,
"stop neo/go %s"
,
n
.
opt
.
workdir
)
panic
(
"TODO"
)
}
func
(
n
*
NEOGoSrv
)
ZUrl
()
string
{
panic
(
"TODO"
)
}
// ----------------
// ----------------
// tOptions represents options for testing.
// tOptions represents options for testing.
...
@@ -237,6 +268,43 @@ func withNEOSrv(t *testing.T, f func(t *testing.T, nsrv NEOSrv), optv ...tOption
...
@@ -237,6 +268,43 @@ func withNEOSrv(t *testing.T, f func(t *testing.T, nsrv NEOSrv), optv ...tOption
kind
:=
""
kind
:=
""
if
ssl
{
kind
=
"ssl"
}
else
{
kind
=
"!ssl"
}
if
ssl
{
kind
=
"ssl"
}
else
{
kind
=
"!ssl"
}
neoOpt
:=
NEOSrvOptions
{
name
:
"1"
,
SSL
:
ssl
,
}
// startNEOpy starts NEO/py server with database in workdir/
// and preloads it with data according to opt.Preload.
startNEOpy
:=
func
(
t
*
testing
.
T
,
workdir
string
)
*
NEOPySrv
{
X
:=
xtesting
.
FatalIf
(
t
)
neoOpt
:=
neoOpt
neoOpt
.
workdir
=
workdir
npy
,
err
:=
StartNEOPySrv
(
neoOpt
);
X
(
err
)
if
opt
.
Preload
!=
""
{
cmd
:=
exec
.
Command
(
"python"
,
"-c"
,
"from neo.scripts.neomigrate import main; main()"
,
"-q"
,
"-c"
,
npy
.
ClusterName
(),
)
if
ssl
{
cmd
.
Args
=
append
(
cmd
.
Args
,
"--ca"
,
npy
.
CA
)
cmd
.
Args
=
append
(
cmd
.
Args
,
"--cert"
,
npy
.
Cert
)
cmd
.
Args
=
append
(
cmd
.
Args
,
"--key"
,
npy
.
Key
)
}
cmd
.
Args
=
append
(
cmd
.
Args
,
opt
.
Preload
,
npy
.
MasterAddr
(),
)
cmd
.
Stdin
=
nil
cmd
.
Stdout
=
os
.
Stdout
cmd
.
Stderr
=
os
.
Stderr
err
:=
cmd
.
Run
();
X
(
err
)
}
return
npy
}
// NEO/py
// NEO/py
t
.
Run
(
"py/"
+
kind
,
func
(
t
*
testing
.
T
)
{
t
.
Run
(
"py/"
+
kind
,
func
(
t
*
testing
.
T
)
{
t
.
Helper
()
t
.
Helper
()
...
@@ -244,40 +312,39 @@ func withNEOSrv(t *testing.T, f func(t *testing.T, nsrv NEOSrv), optv ...tOption
...
@@ -244,40 +312,39 @@ func withNEOSrv(t *testing.T, f func(t *testing.T, nsrv NEOSrv), optv ...tOption
inWorkDir
(
t
,
func
(
workdir
string
)
{
inWorkDir
(
t
,
func
(
workdir
string
)
{
X
:=
xtesting
.
FatalIf
(
t
)
X
:=
xtesting
.
FatalIf
(
t
)
npy
,
err
:=
StartNEOPySrv
(
workdir
,
"1"
,
NEOPyOptions
{
npy
:=
startNEOpy
(
t
,
workdir
)
SSL
:
ssl
,
});
X
(
err
)
defer
func
()
{
defer
func
()
{
err
:=
npy
.
Close
();
X
(
err
)
err
:=
npy
.
Close
();
X
(
err
)
}()
}()
if
opt
.
Preload
!=
""
{
cmd
:=
exec
.
Command
(
"python"
,
"-c"
,
"from neo.scripts.neomigrate import main; main()"
,
"-q"
,
"-c"
,
npy
.
ClusterName
(),
)
if
ssl
{
cmd
.
Args
=
append
(
cmd
.
Args
,
"--ca"
,
npy
.
CA
)
cmd
.
Args
=
append
(
cmd
.
Args
,
"--cert"
,
npy
.
Cert
)
cmd
.
Args
=
append
(
cmd
.
Args
,
"--key"
,
npy
.
Key
)
}
cmd
.
Args
=
append
(
cmd
.
Args
,
opt
.
Preload
,
npy
.
MasterAddr
(),
)
cmd
.
Stdin
=
nil
cmd
.
Stdout
=
os
.
Stdout
cmd
.
Stderr
=
os
.
Stderr
err
:=
cmd
.
Run
();
X
(
err
)
}
f
(
t
,
npy
)
f
(
t
,
npy
)
})
})
})
})
// NEO/go
t
.
Run
(
"go/"
+
kind
,
func
(
t
*
testing
.
T
)
{
t
.
Helper
()
inWorkDir
(
t
,
func
(
workdir
string
)
{
X
:=
xtesting
.
FatalIf
(
t
)
neoOpt
:=
neoOpt
neoOpt
.
workdir
=
workdir
// TODO NEO/go
// start NEO/py first. We need it to create the
// database and to preload it, because NEO/go
// does not support commit.
npy
:=
startNEOpy
(
t
,
workdir
)
err
:=
npy
.
Close
();
X
(
err
)
// now, as the database is created and preloaded, start NEO/go
ngo
,
err
:=
StartNEOGoSrv
(
neoOpt
);
X
(
err
)
defer
func
()
{
err
:=
ngo
.
Close
();
X
(
err
)
}()
f
(
t
,
ngo
)
})
})
}
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment