2016-04-02 19:05:47 +08:00
|
|
|
package configs_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
"reflect"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/opencontainers/runc/libcontainer/configs"
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
"github.com/opencontainers/runtime-spec/specs-go"
|
2016-04-02 19:05:47 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestUnmarshalHooks(t *testing.T) {
|
|
|
|
timeout := time.Second
|
|
|
|
|
2020-05-09 16:05:12 +08:00
|
|
|
hookCmd := configs.NewCommandHook(configs.Command{
|
|
|
|
Path: "/var/vcap/hooks/hook",
|
2016-04-02 19:05:47 +08:00
|
|
|
Args: []string{"--pid=123"},
|
|
|
|
Env: []string{"FOO=BAR"},
|
|
|
|
Dir: "/var/vcap",
|
|
|
|
Timeout: &timeout,
|
|
|
|
})
|
|
|
|
|
2020-05-09 16:05:12 +08:00
|
|
|
hookJson, err := json.Marshal(hookCmd)
|
2016-04-02 19:05:47 +08:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-05-09 16:05:12 +08:00
|
|
|
for _, hookName := range configs.HookNameList {
|
|
|
|
hooks := configs.Hooks{}
|
|
|
|
err = hooks.UnmarshalJSON([]byte(fmt.Sprintf(`{"%s" :[%s]}`, hookName, hookJson)))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-05-14 08:56:55 +08:00
|
|
|
if !reflect.DeepEqual(hooks[hookName], configs.HookList{hookCmd}) {
|
2020-05-09 16:05:12 +08:00
|
|
|
t.Errorf("Expected %s to equal %+v but it was %+v", hookName, hookCmd, hooks[hookName])
|
|
|
|
}
|
2016-04-02 19:05:47 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestUnmarshalHooksWithInvalidData(t *testing.T) {
|
|
|
|
hook := configs.Hooks{}
|
|
|
|
err := hook.UnmarshalJSON([]byte(`{invalid-json}`))
|
|
|
|
if err == nil {
|
|
|
|
t.Error("Expected error to occur but it was nil")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestMarshalHooks(t *testing.T) {
|
|
|
|
timeout := time.Second
|
|
|
|
|
2020-05-09 16:05:12 +08:00
|
|
|
hookCmd := configs.NewCommandHook(configs.Command{
|
|
|
|
Path: "/var/vcap/hooks/hook",
|
2016-04-02 19:05:47 +08:00
|
|
|
Args: []string{"--pid=123"},
|
|
|
|
Env: []string{"FOO=BAR"},
|
|
|
|
Dir: "/var/vcap",
|
|
|
|
Timeout: &timeout,
|
|
|
|
})
|
|
|
|
|
|
|
|
hook := configs.Hooks{
|
2020-05-09 16:05:12 +08:00
|
|
|
configs.Prestart: configs.HookList{hookCmd},
|
|
|
|
configs.CreateRuntime: configs.HookList{hookCmd},
|
|
|
|
configs.CreateContainer: configs.HookList{hookCmd},
|
|
|
|
configs.StartContainer: configs.HookList{hookCmd},
|
|
|
|
configs.Poststart: configs.HookList{hookCmd},
|
|
|
|
configs.Poststop: configs.HookList{hookCmd},
|
2016-04-02 19:05:47 +08:00
|
|
|
}
|
|
|
|
hooks, err := hook.MarshalJSON()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-05-09 16:05:12 +08:00
|
|
|
// Note Marshal seems to output fields in alphabetical order
|
|
|
|
hookCmdJson := `[{"path":"/var/vcap/hooks/hook","args":["--pid=123"],"env":["FOO=BAR"],"dir":"/var/vcap","timeout":1000000000}]`
|
|
|
|
h := fmt.Sprintf(`{"createContainer":%[1]s,"createRuntime":%[1]s,"poststart":%[1]s,"poststop":%[1]s,"prestart":%[1]s,"startContainer":%[1]s}`, hookCmdJson)
|
2016-04-02 19:05:47 +08:00
|
|
|
if string(hooks) != h {
|
|
|
|
t.Errorf("Expected hooks %s to equal %s", string(hooks), h)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestMarshalUnmarshalHooks(t *testing.T) {
|
|
|
|
timeout := time.Second
|
|
|
|
|
2020-05-09 16:05:12 +08:00
|
|
|
hookCmd := configs.NewCommandHook(configs.Command{
|
|
|
|
Path: "/var/vcap/hooks/hook",
|
2016-04-02 19:05:47 +08:00
|
|
|
Args: []string{"--pid=123"},
|
|
|
|
Env: []string{"FOO=BAR"},
|
|
|
|
Dir: "/var/vcap",
|
|
|
|
Timeout: &timeout,
|
|
|
|
})
|
|
|
|
|
|
|
|
hook := configs.Hooks{
|
2020-05-09 16:05:12 +08:00
|
|
|
configs.Prestart: configs.HookList{hookCmd},
|
|
|
|
configs.CreateRuntime: configs.HookList{hookCmd},
|
|
|
|
configs.CreateContainer: configs.HookList{hookCmd},
|
|
|
|
configs.StartContainer: configs.HookList{hookCmd},
|
|
|
|
configs.Poststart: configs.HookList{hookCmd},
|
|
|
|
configs.Poststop: configs.HookList{hookCmd},
|
2016-04-02 19:05:47 +08:00
|
|
|
}
|
|
|
|
hooks, err := hook.MarshalJSON()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
umMhook := configs.Hooks{}
|
|
|
|
err = umMhook.UnmarshalJSON(hooks)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-05-09 16:05:12 +08:00
|
|
|
if !reflect.DeepEqual(umMhook, hook) {
|
|
|
|
t.Errorf("Expected hooks to be equal after mashaling -> unmarshaling them: %+v, %+v", umMhook, hook)
|
2016-04-02 19:05:47 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestMarshalHooksWithUnexpectedType(t *testing.T) {
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
fHook := configs.NewFunctionHook(func(*specs.State) error {
|
2016-04-02 19:05:47 +08:00
|
|
|
return nil
|
|
|
|
})
|
|
|
|
hook := configs.Hooks{
|
2020-05-09 16:05:12 +08:00
|
|
|
configs.CreateRuntime: configs.HookList{fHook},
|
2016-04-02 19:05:47 +08:00
|
|
|
}
|
|
|
|
hooks, err := hook.MarshalJSON()
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2020-05-09 16:05:12 +08:00
|
|
|
h := `{"createContainer":null,"createRuntime":null,"poststart":null,"poststop":null,"prestart":null,"startContainer":null}`
|
2016-04-02 19:05:47 +08:00
|
|
|
if string(hooks) != h {
|
|
|
|
t.Errorf("Expected hooks %s to equal %s", string(hooks), h)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestFuncHookRun(t *testing.T) {
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
state := &specs.State{
|
2017-03-15 00:36:38 +08:00
|
|
|
Version: "1",
|
|
|
|
ID: "1",
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
Status: "created",
|
2017-03-15 00:36:38 +08:00
|
|
|
Pid: 1,
|
|
|
|
Bundle: "/bundle",
|
2016-04-02 19:05:47 +08:00
|
|
|
}
|
|
|
|
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
fHook := configs.NewFunctionHook(func(s *specs.State) error {
|
2016-04-02 19:05:47 +08:00
|
|
|
if !reflect.DeepEqual(state, s) {
|
|
|
|
t.Errorf("Expected state %+v to equal %+v", state, s)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
fHook.Run(state)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCommandHookRun(t *testing.T) {
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
state := &specs.State{
|
2017-03-15 00:36:38 +08:00
|
|
|
Version: "1",
|
|
|
|
ID: "1",
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
Status: "created",
|
2017-03-15 00:36:38 +08:00
|
|
|
Pid: 1,
|
|
|
|
Bundle: "/bundle",
|
2016-04-02 19:05:47 +08:00
|
|
|
}
|
|
|
|
timeout := time.Second
|
|
|
|
|
|
|
|
cmdHook := configs.NewCommandHook(configs.Command{
|
|
|
|
Path: os.Args[0],
|
|
|
|
Args: []string{os.Args[0], "-test.run=TestHelperProcess"},
|
|
|
|
Env: []string{"FOO=BAR"},
|
|
|
|
Dir: "/",
|
|
|
|
Timeout: &timeout,
|
|
|
|
})
|
|
|
|
|
|
|
|
err := cmdHook.Run(state)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf(fmt.Sprintf("Expected error to not occur but it was %+v", err))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCommandHookRunTimeout(t *testing.T) {
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
state := &specs.State{
|
2017-03-15 00:36:38 +08:00
|
|
|
Version: "1",
|
|
|
|
ID: "1",
|
libcontainer: Set 'status' in hook stdin
Finish off the work started in a344b2d6 (sync up `HookState` with OCI
spec `State`, 2016-12-19, #1201).
And drop HookState, since there's no need for a local alias for
specs.State.
Also set c.initProcess in newInitProcess to support OCIState calls
from within initProcess.start(). I think the cyclic references
between linuxContainer and initProcess are unfortunate, but didn't
want to address that here.
I've also left the timing of the Prestart hooks alone, although the
spec calls for them to happen before start (not as part of creation)
[1,2]. Once the timing gets fixed we can drop the
initProcessStartTime hacks which initProcess.start currently needs.
I'm not sure why we trigger the prestart hooks in response to both
procReady and procHooks. But we've had two prestart rounds in
initProcess.start since 2f276498 (Move pre-start hooks after container
mounts, 2016-02-17, #568). I've left that alone too.
I really think we should have len() guards to avoid computing the
state when .Hooks is non-nil but the particular phase we're looking at
is empty. Aleksa, however, is adamantly against them [3] citing a
risk of sloppy copy/pastes causing the hook slice being len-guarded to
diverge from the hook slice being iterated over within the guard. I
think that ort of thing is very lo-risk, because:
* We shouldn't be copy/pasting this, right? DRY for the win :).
* There's only ever a few lines between the guard and the guarded
loop. That makes broken copy/pastes easy to catch in review.
* We should have test coverage for these. Guarding with the wrong
slice is certainly not the only thing you can break with a sloppy
copy/paste.
But I'm not a maintainer ;).
[1]: https://github.com/opencontainers/runtime-spec/blob/v1.0.0/config.md#prestart
[2]: https://github.com/opencontainers/runc/issues/1710
[3]: https://github.com/opencontainers/runc/pull/1741#discussion_r233331570
Signed-off-by: W. Trevor King <wking@tremily.us>
2018-02-26 06:47:41 +08:00
|
|
|
Status: "created",
|
2017-03-15 00:36:38 +08:00
|
|
|
Pid: 1,
|
|
|
|
Bundle: "/bundle",
|
2016-04-02 19:05:47 +08:00
|
|
|
}
|
|
|
|
timeout := (10 * time.Millisecond)
|
|
|
|
|
|
|
|
cmdHook := configs.NewCommandHook(configs.Command{
|
|
|
|
Path: os.Args[0],
|
|
|
|
Args: []string{os.Args[0], "-test.run=TestHelperProcessWithTimeout"},
|
|
|
|
Env: []string{"FOO=BAR"},
|
|
|
|
Dir: "/",
|
|
|
|
Timeout: &timeout,
|
|
|
|
})
|
|
|
|
|
|
|
|
err := cmdHook.Run(state)
|
|
|
|
if err == nil {
|
|
|
|
t.Error("Expected error to occur but it was nil")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestHelperProcess(*testing.T) {
|
|
|
|
fmt.Println("Helper Process")
|
|
|
|
os.Exit(0)
|
|
|
|
}
|
|
|
|
func TestHelperProcessWithTimeout(*testing.T) {
|
|
|
|
time.Sleep(time.Second)
|
|
|
|
}
|