mirror of
https://github.com/vbatts/go-cgroup.git
synced 2025-01-14 17:50:08 +00:00
Merge pull request #5 from dongsupark/fix-get-uid-gid
cg: fix a bug in GetUidGid() to call cgroup_get_uid_gid() correctly
This commit is contained in:
commit
1ab93081d9
2 changed files with 66 additions and 5 deletions
30
cg.go
30
cg.go
|
@ -13,6 +13,7 @@ import "C"
|
|||
import (
|
||||
"errors"
|
||||
"runtime"
|
||||
"strconv"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
|
@ -212,11 +213,11 @@ func (cg Cgroup) GetUIDGID() (tasksUID UID, tasksGID GID, controlUID UID, contro
|
|||
cCU C.uid_t
|
||||
cCG C.gid_t
|
||||
)
|
||||
err = _err(C.cgroup_set_uid_gid(cg.g,
|
||||
cTU,
|
||||
cTG,
|
||||
cCU,
|
||||
cCG))
|
||||
err = _err(C.cgroup_get_uid_gid(cg.g,
|
||||
&cTU,
|
||||
&cTG,
|
||||
&cCU,
|
||||
&cCG))
|
||||
return UID(cTU), GID(cTG), UID(cCU), GID(cCG), err
|
||||
|
||||
}
|
||||
|
@ -561,3 +562,22 @@ func _err(num C.int) error {
|
|||
// There's a lot. We'll create them as they come
|
||||
return errors.New(C.GoString(C.cgroup_strerror(num)))
|
||||
}
|
||||
|
||||
// simple helpers to get UID or GID from a given string
|
||||
func stringToUID(uidStr string) UID {
|
||||
intVal, err := strconv.Atoi(uidStr)
|
||||
if err != nil {
|
||||
return UID(0)
|
||||
}
|
||||
|
||||
return UID(intVal)
|
||||
}
|
||||
|
||||
func stringToGID(gidStr string) GID {
|
||||
intVal, err := strconv.Atoi(gidStr)
|
||||
if err != nil {
|
||||
return GID(0)
|
||||
}
|
||||
|
||||
return GID(intVal)
|
||||
}
|
||||
|
|
41
cg_test.go
Normal file
41
cg_test.go
Normal file
|
@ -0,0 +1,41 @@
|
|||
package cgroup
|
||||
|
||||
import (
|
||||
"os/user"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestUidGid(t *testing.T) {
|
||||
Init()
|
||||
|
||||
var wantTaskUid, wantCtrlUid UID
|
||||
var wantTaskGid, wantCtrlGid GID
|
||||
|
||||
curUser, err := user.Current()
|
||||
if err == nil {
|
||||
wantTaskUid = stringToUID(curUser.Uid)
|
||||
wantTaskGid = stringToGID(curUser.Gid)
|
||||
wantCtrlUid = stringToUID(curUser.Uid)
|
||||
wantCtrlGid = stringToGID(curUser.Gid)
|
||||
} else {
|
||||
t.Logf("cannot get the current user. fall back to 0.\n")
|
||||
wantTaskUid, wantTaskGid, wantCtrlUid, wantCtrlGid = 0, 0, 0, 0
|
||||
}
|
||||
|
||||
cg := NewCgroup("test_cgroup")
|
||||
if err := cg.SetUIDGID(wantTaskUid, wantTaskGid, wantCtrlUid, wantCtrlGid); err != nil {
|
||||
t.Fatalf("cannot set cgroup uids/gids: %v\n", err)
|
||||
}
|
||||
|
||||
gotTaskUid, gotTaskGid, gotCtrlUid, gotCtrlGid, err := cg.GetUIDGID()
|
||||
if err != nil {
|
||||
t.Fatalf("cannot get cgroup uids/gids: %v\n", err)
|
||||
}
|
||||
|
||||
if wantTaskUid != gotTaskUid || wantTaskGid != gotTaskGid ||
|
||||
wantCtrlUid != gotCtrlUid || wantCtrlGid != gotCtrlGid {
|
||||
t.Fatalf("wanted (%d,%d,%d,%d), got (%d,%d,%d,%d)\n",
|
||||
wantTaskUid, wantTaskGid, wantCtrlUid, wantCtrlGid,
|
||||
gotTaskUid, gotTaskGid, gotCtrlUid, gotCtrlGid)
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue