Skip to content
This repository has been archived by the owner on Nov 24, 2024. It is now read-only.

Commit

Permalink
Merge pull request #6 from jackgene/chore/fix-test-on-arm-image
Browse files Browse the repository at this point in the history
Updated testStartingContainerAndRetrievingLogs() to work on Apple Silicon
  • Loading branch information
alexsteinerde authored Feb 21, 2023
2 parents e1393d0 + b5b1258 commit 0c874f7
Showing 1 changed file with 35 additions and 13 deletions.
48 changes: 35 additions & 13 deletions Tests/DockerClientTests/ContainerTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ final class ContainerTests: XCTestCase {
func testCreateContainers() throws {
let image = try client.images.pullImage(byName: "hello-world", tag: "latest").wait()
let container = try client.containers.createContainer(image: image).wait()

XCTAssertEqual(container.command, "/hello")
}

Expand All @@ -26,7 +26,7 @@ final class ContainerTests: XCTestCase {
let _ = try client.containers.createContainer(image: image).wait()

let containers = try client.containers.list(all: true).wait()

XCTAssert(containers.count >= 1)
}

Expand All @@ -45,32 +45,54 @@ final class ContainerTests: XCTestCase {
let container = try client.containers.createContainer(image: image).wait()
try container.start(on: client).wait()
let output = try container.logs(on: client).wait()

XCTAssertEqual(
output,
"""
// Depending on CPU architecture, step 2 of the log output may by:
// 2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
// (amd64)
// or
// 2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
// (arm64v8)
//
// Just check the lines before and after this line
let expectedOutputPrefix = """
Hello from Docker!
This message shows that your installation appears to be working correctly.
To generate this message, Docker took the following steps:
1. The Docker client contacted the Docker daemon.
2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
(amd64)
"""
let expectedOutputSuffix = """
3. The Docker daemon created a new container from that image which runs the
executable that produces the output you are currently reading.
4. The Docker daemon streamed that output to the Docker client, which sent it
to your terminal.
To try something more ambitious, you can run an Ubuntu container with:
$ docker run -it ubuntu bash
Share images, automate workflows, and more with a free Docker ID:
https://hub.docker.com/
For more examples and ideas, visit:
https://docs.docker.com/get-started/
"""

XCTAssertTrue(
output.hasPrefix(expectedOutputPrefix),
"""
"\(output)"
did not start with
"\(expectedOutputPrefix)"
"""
)
XCTAssertTrue(
output.hasSuffix(expectedOutputSuffix),
"""
"\(output)"
did not end with
"\(expectedOutputSuffix)"
"""
)
}
Expand Down

0 comments on commit 0c874f7

Please sign in to comment.