@@ -355,6 +355,9 @@ func testMultipleVMs(ctx context.Context, t *testing.T, count int) {
355
355
stopped int64
356
356
)
357
357
358
+ gen , err := integtest .NewVMIDGen ()
359
+ require .NoError (t , err , "Failed to create a VMIDGen" )
360
+
358
361
// This test spawns separate VMs in parallel and ensures containers are spawned within each expected VM. It asserts each
359
362
// container ends up in the right VM by assigning each VM a network device with a unique mac address and having each container
360
363
// print the mac address it sees inside its VM.
@@ -371,7 +374,7 @@ func testMultipleVMs(ctx context.Context, t *testing.T, count int) {
371
374
372
375
rootfsPath := cfg .RootDrive
373
376
374
- vmIDStr := strconv . Itoa (vmID )
377
+ vmIDStr := gen . VMID (vmID )
375
378
req := & proto.CreateVMRequest {
376
379
KernelArgs : kernelArgs ,
377
380
VMID : vmIDStr ,
@@ -435,21 +438,21 @@ func testMultipleVMs(ctx context.Context, t *testing.T, count int) {
435
438
}
436
439
437
440
// verify duplicate CreateVM call fails with right error
438
- _ , err = fcClient .CreateVM (ctx , & proto.CreateVMRequest {VMID : strconv . Itoa ( vmID ) })
441
+ _ , err = fcClient .CreateVM (ctx , & proto.CreateVMRequest {VMID : vmIDStr })
439
442
if err == nil {
440
443
return fmt .Errorf ("creating the same VM must return an error" )
441
444
}
442
445
443
446
// verify GetVMInfo returns expected data
444
- vmInfoResp , err := fcClient .GetVMInfo (ctx , & proto.GetVMInfoRequest {VMID : strconv . Itoa ( vmID ) })
447
+ vmInfoResp , err := fcClient .GetVMInfo (ctx , & proto.GetVMInfoRequest {VMID : vmIDStr })
445
448
if err != nil {
446
449
return err
447
450
}
448
- if vmInfoResp .VMID != strconv . Itoa ( vmID ) {
449
- return fmt .Errorf ("%q must be %q" , vmInfoResp .VMID , strconv . Itoa ( vmID ) )
451
+ if vmInfoResp .VMID != vmIDStr {
452
+ return fmt .Errorf ("%q must be %q" , vmInfoResp .VMID , vmIDStr )
450
453
}
451
454
452
- nspVMid := defaultNamespace + "#" + strconv . Itoa ( vmID )
455
+ nspVMid := defaultNamespace + "#" + vmIDStr
453
456
cfg , err := config .LoadConfig ("" )
454
457
if err != nil {
455
458
return err
@@ -465,7 +468,7 @@ func testMultipleVMs(ctx context.Context, t *testing.T, count int) {
465
468
// just verify that updating the metadata doesn't return an error, a separate test case is needed
466
469
// to very the MMDS update propagates to the container correctly
467
470
_ , err = fcClient .SetVMMetadata (ctx , & proto.SetVMMetadataRequest {
468
- VMID : strconv . Itoa ( vmID ) ,
471
+ VMID : vmIDStr ,
469
472
Metadata : "{}" ,
470
473
})
471
474
if err != nil {
@@ -477,7 +480,7 @@ func testMultipleVMs(ctx context.Context, t *testing.T, count int) {
477
480
return fmt .Errorf ("unexpected error from the containers in VM %d: %w" , vmID , err )
478
481
}
479
482
480
- _ , err = fcClient .StopVM (ctx , & proto.StopVMRequest {VMID : strconv . Itoa ( vmID ) , TimeoutSeconds : 5 })
483
+ _ , err = fcClient .StopVM (ctx , & proto.StopVMRequest {VMID : vmIDStr , TimeoutSeconds : 5 })
481
484
atomic .AddInt64 (& stopped , 1 )
482
485
return err
483
486
}
@@ -515,13 +518,14 @@ loop:
515
518
func testMultipleExecs (
516
519
ctx context.Context ,
517
520
vmID int ,
521
+ gen * integtest.VMIDGen ,
518
522
containerID int ,
519
523
client * containerd.Client ,
520
524
image containerd.Image ,
521
525
jailerConfig * proto.JailerConfig ,
522
526
cgroupPath string ,
523
527
) error {
524
- vmIDStr := strconv . Itoa (vmID )
528
+ vmIDStr := gen . VMID (vmID )
525
529
testTimeout := 600 * time .Second
526
530
527
531
containerName := fmt .Sprintf ("container-%d-%d" , vmID , containerID )
@@ -826,6 +830,9 @@ func TestStubBlockDevices_Isolated(t *testing.T) {
826
830
827
831
const vmID = 0
828
832
833
+ gen , err := integtest .NewVMIDGen ()
834
+ require .NoError (t , err , "failed to create VMIDGen" )
835
+
829
836
ctx := namespaces .WithNamespace (context .Background (), "default" )
830
837
831
838
client , err := containerd .New (integtest .ContainerdSockPath , containerd .WithDefaultRuntime (firecrackerRuntime ))
@@ -846,7 +853,7 @@ func TestStubBlockDevices_Isolated(t *testing.T) {
846
853
require .NoError (t , err , "failed to create fccontrol client" )
847
854
848
855
_ , err = fcClient .CreateVM (ctx , & proto.CreateVMRequest {
849
- VMID : strconv . Itoa (vmID ),
856
+ VMID : gen . VMID (vmID ),
850
857
NetworkInterfaces : []* proto.FirecrackerNetworkInterface {
851
858
{
852
859
AllowMMDS : true ,
@@ -865,7 +872,7 @@ func TestStubBlockDevices_Isolated(t *testing.T) {
865
872
containerd .WithSnapshotter (defaultSnapshotterName ),
866
873
containerd .WithNewSnapshot (snapshotName , image ),
867
874
containerd .WithNewSpec (
868
- firecrackeroci .WithVMID (strconv . Itoa (vmID )),
875
+ firecrackeroci .WithVMID (gen . VMID (vmID )),
869
876
oci .WithProcessArgs ("/bin/sh" , "/var/firecracker-containerd-test/scripts/lsblk.sh" ),
870
877
871
878
oci .WithMounts ([]specs.Mount {
@@ -1447,6 +1454,9 @@ func TestMemoryBalloon_Isolated(t *testing.T) {
1447
1454
}
1448
1455
t .Logf ("TestMemoryBalloon_Isolated: will run %d vm's" , numberOfVms )
1449
1456
1457
+ gen , err := integtest .NewVMIDGen ()
1458
+ require .NoError (t , err , "Failed to create a VMIDGen" )
1459
+
1450
1460
var vmGroup sync.WaitGroup
1451
1461
for i := 0 ; i < numberOfVms ; i ++ {
1452
1462
vmGroup .Add (1 )
@@ -1462,7 +1472,7 @@ func TestMemoryBalloon_Isolated(t *testing.T) {
1462
1472
require .NoError (t , err , "failed to create fccontrol client" )
1463
1473
1464
1474
_ , err = fcClient .CreateVM (ctx , & proto.CreateVMRequest {
1465
- VMID : strconv . Itoa (vmID ),
1475
+ VMID : gen . VMID (vmID ),
1466
1476
MachineCfg : & proto.FirecrackerMachineConfiguration {
1467
1477
MemSizeMib : 512 ,
1468
1478
},
@@ -1484,7 +1494,7 @@ func TestMemoryBalloon_Isolated(t *testing.T) {
1484
1494
require .NoError (t , err , "failed to create vm" )
1485
1495
1486
1496
// Test UpdateBalloon correctly updates amount of memory for the balloon device
1487
- vmIDStr := strconv . Itoa (vmID )
1497
+ vmIDStr := gen . VMID (vmID )
1488
1498
newAmountMib := int64 (50 )
1489
1499
_ , err = fcClient .UpdateBalloon (ctx , & proto.UpdateBalloonRequest {
1490
1500
VMID : vmIDStr ,
0 commit comments