syzkaller/sys/decl_test.go
Dmitry Vyukov e8ddc2ae56 sys: don't add clock_gettime always
Currently we always enable clock_gettime in config.
This is required since the call is needed for generation of timespec/timeval structs.
The negative side effect is that one gets clock_gettime even
if he wants to fuzz a small set of unrelated syscalls.

Don't enable clock_gettime by default.
Instead handle timeval/timespec as other resources.
2017-01-09 20:20:48 +01:00

49 lines
1.4 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 sys
import (
"testing"
)
func TestTransitivelyEnabledCalls(t *testing.T) {
calls := make(map[*Call]bool)
for _, c := range Calls {
calls[c] = true
}
if trans := TransitivelyEnabledCalls(calls); len(calls) != len(trans) {
for c := range calls {
if !trans[c] {
t.Logf("disabled %v", c.Name)
}
}
t.Fatalf("can't create some resource")
}
delete(calls, CallMap["epoll_create"])
if trans := TransitivelyEnabledCalls(calls); len(calls) != len(trans) {
t.Fatalf("still must be able to create epoll fd with epoll_create1")
}
delete(calls, CallMap["epoll_create1"])
trans := TransitivelyEnabledCalls(calls)
if len(calls)-3 != len(trans) ||
trans[CallMap["epoll_ctl"]] ||
trans[CallMap["epoll_wait"]] ||
trans[CallMap["epoll_pwait"]] {
t.Fatalf("epoll fd is not disabled")
}
}
func TestClockGettime(t *testing.T) {
calls := make(map[*Call]bool)
for _, c := range Calls {
calls[c] = true
}
// Removal of clock_gettime should disable all calls that accept timespec/timeval.
delete(calls, CallMap["clock_gettime"])
trans := TransitivelyEnabledCalls(calls)
if len(trans)+10 > len(calls) {
t.Fatalf("clock_gettime did not disable enough calls: before %v, after %v", len(calls), len(trans))
}
}