Merge pull request #1691 from quentingllmt/fix/compose_drivers_opts_to_docker

Fix passing driver_opts from compose to docker network creation
This commit is contained in:
bulldozer-balena[bot] 2021-05-06 15:40:52 +00:00 committed by GitHub
commit 3787dfc3dd
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 57 additions and 0 deletions

View File

@ -130,6 +130,7 @@ export class Network {
Name: Network.generateDockerName(this.appId, this.name), Name: Network.generateDockerName(this.appId, this.name),
Driver: this.config.driver, Driver: this.config.driver,
CheckDuplicate: true, CheckDuplicate: true,
Options: this.config.options,
IPAM: { IPAM: {
Driver: this.config.ipam.driver, Driver: this.config.ipam.driver,
Config: this.config.ipam.config.map((conf) => { Config: this.config.ipam.config.map((conf) => {

View File

@ -110,6 +110,62 @@ describe('compose/network', () => {
'Network IPAM config entries must have both a subnet and gateway', 'Network IPAM config entries must have both a subnet and gateway',
); );
}); });
it('parses values from a compose object', () => {
const network1 = Network.fromComposeObject('default', 12345, {
driver: 'bridge',
enable_ipv6: true,
internal: false,
ipam: {
driver: 'default',
options: {
'com.docker.ipam-option': 'abcd',
},
config: [
{
subnet: '172.18.0.0/16',
gateway: '172.18.0.1',
},
],
},
driver_opts: {
'com.docker.network-option': 'abcd',
},
labels: {
'com.docker.some-label': 'yes',
},
});
const dockerConfig = network1.toDockerConfig();
expect(dockerConfig.Driver).to.equal('bridge');
// Check duplicate forced to be true
expect(dockerConfig.CheckDuplicate).to.equal(true);
expect(dockerConfig.Internal).to.equal(false);
expect(dockerConfig.EnableIPv6).to.equal(true);
expect(dockerConfig.IPAM).to.deep.equal({
Driver: 'default',
Options: {
'com.docker.ipam-option': 'abcd',
},
Config: [
{
Subnet: '172.18.0.0/16',
Gateway: '172.18.0.1',
},
],
});
expect(dockerConfig.Labels).to.deep.equal({
'io.balena.supervised': 'true',
'com.docker.some-label': 'yes',
});
expect(dockerConfig.Options).to.deep.equal({
'com.docker.network-option': 'abcd',
});
});
}); });
describe('creating a network from docker engine state', () => { describe('creating a network from docker engine state', () => {