tests/testthat/test-add-heatmap.R

test_that("add_heatmap works", {
  gene_expression |>
    tidyplot(x = sample, y = external_gene_name, color = expression) |>
    add_heatmap(scale = "row") |>
    adjust_size(height = 90) |>
    vdiffr::expect_doppelganger("heatmap with scale row", fig = _)

  gene_expression |>
    tidyplot(x = sample, y = external_gene_name, color = expression) |>
    add_heatmap(scale = "column") |>
    adjust_size(height = 90) |>
    vdiffr::expect_doppelganger("heatmap with scale column", fig = _)

  gene_expression |>
    tidyplot(x = sample, y = external_gene_name, color = expression) |>
    add_heatmap() |>
    adjust_size(height = 90) |>
    vdiffr::expect_doppelganger("heatmap without scaling", fig = _)

  hm <-
    gene_expression |>
    tidyplot(x = sample, y = external_gene_name, color = expression) |>
    add_heatmap(scale = "row") |>
    adjust_size(height = 90)

  hm |> reorder_y_axis_labels("Bsn") |>
    vdiffr::expect_doppelganger("heatmap reorder y axis 1", fig = _)
  hm |> reorder_y_axis_labels(c("Bsn", "Apol6")) |>
    vdiffr::expect_doppelganger("heatmap reorder y axis 2", fig = _)
  hm |> reorder_x_axis_labels("Hin_3") |>
    vdiffr::expect_doppelganger("heatmap reorder x axis 1", fig = _)

  hm |> sort_y_axis_labels(direction) |>
    vdiffr::expect_doppelganger("heatmap sort y 1", fig = _)
  hm |> sort_y_axis_labels(direction, -padj) |>
    vdiffr::expect_doppelganger("heatmap sort y 2", fig = _)
  hm |> sort_y_axis_labels(expression) |>
    vdiffr::expect_doppelganger("heatmap sort y 3", fig = _)
  hm |> sort_x_axis_labels(group) |>
    vdiffr::expect_doppelganger("heatmap sort x 1", fig = _)
  hm |> sort_x_axis_labels(sample_type) |>
    vdiffr::expect_doppelganger("heatmap sort x 2", fig = _)
  hm |> sort_x_axis_labels(desc(sample_type)) |>
    vdiffr::expect_doppelganger("heatmap sort x 3", fig = _)
  hm |> sort_x_axis_labels(condition) |>
    vdiffr::expect_doppelganger("heatmap sort x 4", fig = _)

  hm |> reverse_x_axis_labels() |>
    vdiffr::expect_doppelganger("heatmap reverse x", fig = _)
  hm |> reverse_y_axis_labels() |>
    vdiffr::expect_doppelganger("heatmap reverse y", fig = _)

  hm |> rename_x_axis_labels(new_names = c("Ein_1" = "Hallo")) |>
    vdiffr::expect_doppelganger("heatmap rename x", fig = _)
  hm |> rename_y_axis_labels(new_names = c("Bsn" = "Juhooooooooooooooo!",
                                            "Aip" = "Rabbithoooooooooooole")) |>
    vdiffr::expect_doppelganger("heatmap rename y", fig = _)
})

test_that("rasterize works", {
  gene_expression |>
    tidyplot(x = sample, y = external_gene_name, color = expression) |>
    add_heatmap(scale = "row", rasterize = TRUE, rasterize_dpi = 20) |>
    adjust_size(height = 90) |>
    vdiffr::expect_doppelganger("rasterize heatmap", fig = _)
})

Try the tidyplots package in your browser

Any scripts or data that you put into this service are public.

tidyplots documentation built on April 3, 2025, 9:33 p.m.