Skip to content

MySQL Module

MySQL is the world's most popular open source database. With its proven performance, reliability and ease-of-use, MySQL has become the leading database choice for web-based applications, covering the entire range from personal projects and websites, via e-commerce and information services, all the way to high profile web properties including Facebook, Twitter, YouTube, Yahoo! and many more.

Install

npm install @testcontainers/mysql --save-dev

Examples

it("should connect and execute query", async () => {
  const container = await new MySqlContainer().start();

  const client = await createConnection({
    host: container.getHost(),
    port: container.getPort(),
    database: container.getDatabase(),
    user: container.getUsername(),
    password: container.getUserPassword(),
  });

  const [rows] = await client.execute("SELECT 1 as res");
  expect(rows).toEqual([{ res: 1 }]);

  await client.end();
  await container.stop();
});
it("should work with database URI", async () => {
  const username = "testUser";
  const password = "testPassword";
  const database = "testDB";

  // Test non-root user
  const container = await new MySqlContainer()
    .withUsername(username)
    .withUserPassword(password)
    .withDatabase(database)
    .start();
  expect(container.getConnectionUri()).toEqual(
    `mysql://${username}:${password}@${container.getHost()}:${container.getPort()}/${database}`
  );
  await container.stop();

  // Test root user
  const rootContainer = await new MySqlContainer().withRootPassword(password).withDatabase(database).start();
  expect(rootContainer.getConnectionUri(true)).toEqual(
    `mysql://root:${password}@${rootContainer.getHost()}:${rootContainer.getPort()}/${database}`
  );
  await rootContainer.stop();
});
it("should set username", async () => {
  const container = await new MySqlContainer().withUsername("customUsername").start();

  const client = await createConnection({
    host: container.getHost(),
    port: container.getPort(),
    database: container.getDatabase(),
    user: container.getUsername(),
    password: container.getUserPassword(),
  });

  const [rows] = await client.execute("SELECT CURRENT_USER() as res");
  expect(rows).toEqual([{ res: "customUsername@%" }]);

  await client.end();
  await container.stop();
});
it("should execute a query and return the result", async () => {
  const container = await new MySqlContainer().start();

  const queryResult = await container.executeQuery("SELECT 1 as res");
  expect(queryResult).toEqual(expect.stringContaining("res\n1\n"));

  await container.stop();
});

it("should execute a query as root user", async () => {
  const container = await new MySqlContainer().withUsername("customUsername").start();

  // Test non-root user
  const queryResult = await container.executeQuery("SELECT CURRENT_USER() as user");
  expect(queryResult).toEqual(expect.stringContaining("user\ncustomUsername"));

  // Test root user
  const rootQueryResult = await container.executeQuery("SELECT CURRENT_USER() as user", [], true);
  expect(rootQueryResult).toEqual(expect.stringContaining("user\nroot"));

  await container.stop();
});