mirror of https://github.com/docker/compose.git
Add unit tests for combinedConfigFiles logic ✅
Signed-off-by: Vedant Koditkar <vedant.koditkar@outlook.com>
This commit is contained in:
parent
90ca37344f
commit
cb45c6f2df
|
@ -17,6 +17,7 @@
|
||||||
package compose
|
package compose
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
"github.com/docker/compose/v2/pkg/api"
|
"github.com/docker/compose/v2/pkg/api"
|
||||||
|
@ -66,3 +67,56 @@ func TestStacksMixedStatus(t *testing.T) {
|
||||||
assert.Equal(t, combinedStatus([]string{"running", "running", "running"}), "running(3)")
|
assert.Equal(t, combinedStatus([]string{"running", "running", "running"}), "running(3)")
|
||||||
assert.Equal(t, combinedStatus([]string{"running", "exited", "running"}), "exited(1), running(2)")
|
assert.Equal(t, combinedStatus([]string{"running", "exited", "running"}), "exited(1), running(2)")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestCombinedConfigFiles(t *testing.T) {
|
||||||
|
containersByLabel := map[string][]moby.Container{
|
||||||
|
"project1": {
|
||||||
|
{
|
||||||
|
ID: "service1",
|
||||||
|
State: "running",
|
||||||
|
Labels: map[string]string{api.ProjectLabel: "project1", api.ConfigFilesLabel: "/home/docker-compose.yaml"},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
ID: "service2",
|
||||||
|
State: "running",
|
||||||
|
Labels: map[string]string{api.ProjectLabel: "project1", api.ConfigFilesLabel: "/home/docker-compose.yaml"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"project2": {
|
||||||
|
{
|
||||||
|
ID: "service3",
|
||||||
|
State: "running",
|
||||||
|
Labels: map[string]string{api.ProjectLabel: "project2", api.ConfigFilesLabel: "/home/project2-docker-compose.yaml"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"project3": {
|
||||||
|
{
|
||||||
|
ID: "service4",
|
||||||
|
State: "running",
|
||||||
|
Labels: map[string]string{api.ProjectLabel: "project3"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
testData := map[string]struct {
|
||||||
|
ConfigFiles string
|
||||||
|
Error error
|
||||||
|
}{
|
||||||
|
"project1": {ConfigFiles: "/home/docker-compose.yaml", Error: nil},
|
||||||
|
"project2": {ConfigFiles: "/home/project2-docker-compose.yaml", Error: nil},
|
||||||
|
"project3": {ConfigFiles: "", Error: fmt.Errorf("No label %q set on container %q of compose project", api.ConfigFilesLabel, "service4")},
|
||||||
|
}
|
||||||
|
|
||||||
|
for project, containers := range containersByLabel {
|
||||||
|
configFiles, err := combinedConfigFiles(containers)
|
||||||
|
|
||||||
|
expected := testData[project]
|
||||||
|
|
||||||
|
if expected.Error != nil {
|
||||||
|
assert.Equal(t, err.Error(), expected.Error.Error())
|
||||||
|
} else {
|
||||||
|
assert.Equal(t, err, expected.Error)
|
||||||
|
}
|
||||||
|
assert.Equal(t, configFiles, expected.ConfigFiles)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue