proc.Tree() func do not depend on sorted procs list (#647)

* proc.Tree() func do not depend on sorted procs list

* Add test case

Signed-off-by: 6543 <6543@obermui.de>
This commit is contained in:
6543 2021-12-31 17:43:09 +01:00 committed by GitHub
parent d11b2bb8e5
commit 30c3e139d7
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 83 additions and 6 deletions

View file

@ -71,17 +71,25 @@ func (p *Proc) IsParent() bool {
// Tree creates a process tree from a flat process list. // Tree creates a process tree from a flat process list.
func Tree(procs []*Proc) ([]*Proc, error) { func Tree(procs []*Proc) ([]*Proc, error) {
var nodes []*Proc var nodes []*Proc
for _, proc := range procs {
if proc.PPID == 0 { // init parent nodes
nodes = append(nodes, proc) for i := range procs {
} else { if procs[i].IsParent() {
parent, err := findNode(nodes, proc.PPID) nodes = append(nodes, procs[i])
}
}
// assign children to parrents
for i := range procs {
if !procs[i].IsParent() {
parent, err := findNode(nodes, procs[i].PPID)
if err != nil { if err != nil {
return nil, err return nil, err
} }
parent.Children = append(parent.Children, proc) parent.Children = append(parent.Children, procs[i])
} }
} }
return nodes, nil return nodes, nil
} }

69
server/model/proc_test.go Normal file
View file

@ -0,0 +1,69 @@
// Copyright 2021 Woodpecker Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package model
import (
"testing"
"github.com/stretchr/testify/assert"
)
func TestTree(t *testing.T) {
procs := []*Proc{{
ID: 25,
PID: 2,
BuildID: 6,
PPID: 1,
PGID: 2,
Name: "clone",
State: StatusSuccess,
Error: "0",
}, {
ID: 24,
BuildID: 6,
PID: 1,
PPID: 0,
PGID: 1,
Name: "lint",
State: StatusFailure,
Error: "1",
}, {
ID: 26,
BuildID: 6,
PID: 3,
PPID: 1,
PGID: 3,
Name: "lint",
State: StatusFailure,
Error: "1",
}}
procs, err := Tree(procs)
assert.NoError(t, err)
assert.Len(t, procs, 1)
assert.Len(t, procs[0].Children, 2)
procs = []*Proc{{
ID: 25,
PID: 2,
BuildID: 6,
PPID: 1,
PGID: 2,
Name: "clone",
State: StatusSuccess,
Error: "0",
}}
_, err = Tree(procs)
assert.Error(t, err)
}