|
| 1 | +package calcium |
| 2 | + |
| 3 | +import ( |
| 4 | + "context" |
| 5 | + "testing" |
| 6 | + |
| 7 | + enginemocks "github.com/projecteru2/core/engine/mocks" |
| 8 | + lockmocks "github.com/projecteru2/core/lock/mocks" |
| 9 | + "github.com/projecteru2/core/scheduler" |
| 10 | + schedulermocks "github.com/projecteru2/core/scheduler/mocks" |
| 11 | + storemocks "github.com/projecteru2/core/store/mocks" |
| 12 | + "github.com/projecteru2/core/strategy" |
| 13 | + "github.com/projecteru2/core/types" |
| 14 | + "github.com/stretchr/testify/assert" |
| 15 | + "github.com/stretchr/testify/mock" |
| 16 | +) |
| 17 | + |
| 18 | +func TestCalculateCapacity(t *testing.T) { |
| 19 | + c := NewTestCluster() |
| 20 | + scheduler.InitSchedulerV1(c.scheduler) |
| 21 | + ctx := context.Background() |
| 22 | + store := c.store.(*storemocks.Store) |
| 23 | + engine := &enginemocks.API{} |
| 24 | + |
| 25 | + // pod1 := &types.Pod{Name: "p1"} |
| 26 | + node1 := &types.Node{ |
| 27 | + Name: "n1", |
| 28 | + Engine: engine, |
| 29 | + CPU: types.CPUMap{"0": 100, "1": 100}, |
| 30 | + } |
| 31 | + store.On("GetNode", mock.Anything, mock.Anything).Return(node1, nil) |
| 32 | + lock := &lockmocks.DistributedLock{} |
| 33 | + lock.On("Lock", mock.Anything).Return(nil) |
| 34 | + lock.On("Unlock", mock.Anything).Return(nil) |
| 35 | + store.On("CreateLock", mock.Anything, mock.Anything).Return(lock, nil) |
| 36 | + // failed by wrong resource |
| 37 | + opts := &types.DeployOptions{ |
| 38 | + ResourceOpts: types.ResourceOptions{ |
| 39 | + CPUBind: true, |
| 40 | + CPUQuotaRequest: 0, |
| 41 | + }, |
| 42 | + DeployStrategy: strategy.Auto, |
| 43 | + Nodenames: []string{"n1"}, |
| 44 | + } |
| 45 | + _, err := c.CalculateCapacity(ctx, opts) |
| 46 | + assert.Error(t, err) |
| 47 | + opts.ResourceOpts.CPUBind = false |
| 48 | + opts.ResourceOpts.CPUQuotaRequest = 0.5 |
| 49 | + opts.Count = 5 |
| 50 | + sched := c.scheduler.(*schedulermocks.Scheduler) |
| 51 | + // define nodesInfo |
| 52 | + nodesInfo := []types.NodeInfo{ |
| 53 | + { |
| 54 | + Name: "n1", |
| 55 | + MemCap: 100, |
| 56 | + Deploy: 5, |
| 57 | + Capacity: 10, |
| 58 | + Count: 1, |
| 59 | + }, |
| 60 | + } |
| 61 | + sched.On("SelectMemoryNodes", mock.Anything, mock.Anything, mock.Anything).Return(nodesInfo, 5, nil) |
| 62 | + sched.On("SelectStorageNodes", mock.Anything, mock.Anything).Return(nodesInfo, 5, nil) |
| 63 | + sched.On("SelectVolumeNodes", mock.Anything, mock.Anything).Return(nodesInfo, nil, 5, nil) |
| 64 | + store.On("MakeDeployStatus", mock.Anything, mock.Anything, mock.Anything).Return(nil) |
| 65 | + r, err := c.CalculateCapacity(ctx, opts) |
| 66 | + assert.NoError(t, err) |
| 67 | + assert.Equal(t, r.Total, 5) |
| 68 | +} |
0 commit comments