mirror of
https://github.com/reactos/syzkaller.git
synced 2024-11-28 05:40:26 +00:00
c8e73b95c6
Also add a test for this.
141 lines
3.1 KiB
Go
141 lines
3.1 KiB
Go
// Copyright 2015 syzkaller project authors. All rights reserved.
|
|
// Use of this source code is governed by Apache 2 LICENSE that can be found in the LICENSE file.
|
|
|
|
package ipc
|
|
|
|
import (
|
|
"fmt"
|
|
"math/rand"
|
|
"os"
|
|
"path/filepath"
|
|
"runtime"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/google/syzkaller/pkg/csource"
|
|
"github.com/google/syzkaller/pkg/osutil"
|
|
"github.com/google/syzkaller/prog"
|
|
_ "github.com/google/syzkaller/sys"
|
|
)
|
|
|
|
const timeout = 10 * time.Second
|
|
|
|
func buildExecutor(t *testing.T, target *prog.Target) string {
|
|
src := fmt.Sprintf("../../executor/executor_%v.cc", target.OS)
|
|
return buildProgram(t, target, filepath.FromSlash(src))
|
|
}
|
|
|
|
func buildSource(t *testing.T, target *prog.Target, src []byte) string {
|
|
tmp, err := osutil.WriteTempFile(src)
|
|
if err != nil {
|
|
t.Fatalf("%v", err)
|
|
}
|
|
defer os.Remove(tmp)
|
|
return buildProgram(t, target, tmp)
|
|
}
|
|
|
|
func buildProgram(t *testing.T, target *prog.Target, src string) string {
|
|
bin, err := csource.Build(target, "c++", src)
|
|
if err != nil {
|
|
t.Fatalf("%v", err)
|
|
}
|
|
return bin
|
|
}
|
|
|
|
func initTest(t *testing.T) (*prog.Target, rand.Source, int, EnvFlags) {
|
|
t.Parallel()
|
|
iters := 100
|
|
if testing.Short() {
|
|
iters = 10
|
|
}
|
|
seed := int64(time.Now().UnixNano())
|
|
rs := rand.NewSource(seed)
|
|
t.Logf("seed=%v", seed)
|
|
target, err := prog.GetTarget(runtime.GOOS, runtime.GOARCH)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
cfg, _, err := DefaultConfig()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
flags := cfg.Flags & (FlagUseShmem | FlagUseForkServer)
|
|
return target, rs, iters, flags
|
|
}
|
|
|
|
func TestSimpleProg(t *testing.T) {
|
|
target, _, _, flags0 := initTest(t)
|
|
|
|
bin := buildExecutor(t, target)
|
|
defer os.Remove(bin)
|
|
|
|
cfg := &Config{
|
|
Executor: bin,
|
|
Flags: flags0,
|
|
Timeout: timeout,
|
|
}
|
|
env, err := MakeEnv(cfg, 0)
|
|
if err != nil {
|
|
t.Fatalf("failed to create env: %v", err)
|
|
}
|
|
defer env.Close()
|
|
p := target.GenerateSimpleProg()
|
|
opts := &ExecOpts{}
|
|
output, info, failed, hanged, err := env.Exec(opts, p)
|
|
if err != nil {
|
|
t.Fatalf("failed to run executor: %v", err)
|
|
}
|
|
if hanged {
|
|
t.Fatalf("program hanged:\n%s", output)
|
|
}
|
|
if failed {
|
|
t.Fatalf("program failed:\n%s", output)
|
|
}
|
|
if len(info) == 0 {
|
|
t.Fatalf("no calls executed:\n%s", output)
|
|
}
|
|
if info[0].Errno != 0 {
|
|
t.Fatalf("simple call failed: %v\n%s", info[0].Errno, output)
|
|
}
|
|
if len(output) != 0 {
|
|
t.Fatalf("output on empty program")
|
|
}
|
|
}
|
|
|
|
func TestExecute(t *testing.T) {
|
|
target, rs, iters, configFlags := initTest(t)
|
|
|
|
bin := buildExecutor(t, target)
|
|
defer os.Remove(bin)
|
|
|
|
flags := []ExecFlags{0, FlagThreaded, FlagThreaded | FlagCollide}
|
|
for _, flag := range flags {
|
|
t.Logf("testing flags 0x%x\n", flag)
|
|
cfg := &Config{
|
|
Executor: bin,
|
|
Flags: configFlags,
|
|
Timeout: timeout,
|
|
}
|
|
env, err := MakeEnv(cfg, 0)
|
|
if err != nil {
|
|
t.Fatalf("failed to create env: %v", err)
|
|
}
|
|
defer env.Close()
|
|
|
|
for i := 0; i < iters/len(flags); i++ {
|
|
p := target.Generate(rs, 10, nil)
|
|
if i == 0 {
|
|
p = target.GenerateSimpleProg()
|
|
}
|
|
opts := &ExecOpts{
|
|
Flags: flag,
|
|
}
|
|
output, _, _, _, err := env.Exec(opts, p)
|
|
if err != nil {
|
|
t.Logf("program:\n%s\n", p.Serialize())
|
|
t.Fatalf("failed to run executor: %v\n%s", err, output)
|
|
}
|
|
}
|
|
}
|
|
}
|