From 9e043e71ee4b7faa63dacef05bc1a7a5d80772f3 Mon Sep 17 00:00:00 2001 From: Jackson Hoffart Date: Tue, 23 Jan 2024 15:49:19 +0100 Subject: [PATCH] `plot_emission_intensity` correctly orders `scale_colour_r2dii` input (#528) * add failing test * update test to expose plotting step * update test to expose scaling * migrate test to appropriate function * `labels` arg becomes `colour_labels` * remove forced factor levels * remove `match_lines_order` from test * suppress deprecation warning in tests * update news * tests wont run with suppressWarnings on R < 4 --- NEWS.md | 7 ++ R/plot_emission_intensity.R | 10 +-- R/scale_colour_r2dii.R | 18 ++--- man/scale_colour_r2dii.Rd | 8 +-- tests/testthat/_snaps/scale_colour_r2dii.md | 4 +- tests/testthat/test-scale_colour_r2dii.R | 78 ++++++++++++++++++++- 6 files changed, 99 insertions(+), 26 deletions(-) diff --git a/NEWS.md b/NEWS.md index 3661cd69..84cedd79 100644 --- a/NEWS.md +++ b/NEWS.md @@ -1,5 +1,12 @@ # r2dii.plot (development version) +## Breaking change +* `scale_colour_r2dii` has argument renamed from `labels` to `colour_labels` (#527). + +## Bug fixes +* `scale_colour_r2dii`, with input colours and levels, now outputs line plot + with correctly coloured lines (#527). + ## New features * techmix plot does not show the start year scenario bar anymore. (#513) diff --git a/R/plot_emission_intensity.R b/R/plot_emission_intensity.R index 58000111..89d2badd 100644 --- a/R/plot_emission_intensity.R +++ b/R/plot_emission_intensity.R @@ -87,7 +87,7 @@ plot_emission_intensity_impl <- function(data) { aes( x = .data$year, y = .data$emission_factor_value, - colour = match_lines_order(data) + colour = .data$label ) ) + geom_line() + @@ -97,11 +97,3 @@ plot_emission_intensity_impl <- function(data) { scale_colour_manual(values = unique(data$hex)) + theme_2dii() } - -match_lines_order <- function(data) { - forcats::fct_reorder2( - data$label, - data$year, - data$emission_factor_value - ) -} diff --git a/R/scale_colour_r2dii.R b/R/scale_colour_r2dii.R index c84d3668..ab98e950 100644 --- a/R/scale_colour_r2dii.R +++ b/R/scale_colour_r2dii.R @@ -2,9 +2,9 @@ #' #' A custom discrete colour and fill scales with colours from 2DII palette. #' -#' @param labels A character vector. Specifies colour labels to use and their +#' @param colour_labels A character vector. Specifies colour labels to use and their #' order. Run `unique(r2dii.plot:::palette_colours$label)` to see available -#' labels. Similar to `value` parameter in [ggplot2::scale_colour_manual()]. +#' colours. Similar to `value` parameter in [ggplot2::scale_colour_manual()]. #' @param ... Other parameters passed on to [ggplot2::discrete_scale()]. #' #' @return An object of class "ScaleDiscrete". @@ -23,17 +23,17 @@ #' ggplot(mpg) + #' geom_histogram(aes(cyl, fill = class), position = "dodge", bins = 5) + #' scale_fill_r2dii() -scale_colour_r2dii <- function(labels = NULL, ...) { - discrete_scale("colour", "r2dii", r2dii_pal(labels), ...) +scale_colour_r2dii <- function(colour_labels = NULL, ...) { + discrete_scale("colour", "r2dii", r2dii_pal(colour_labels), ...) } #' @rdname scale_colour_r2dii #' @export -scale_fill_r2dii <- function(labels = NULL, ...) { - discrete_scale("fill", "r2dii", r2dii_pal(labels), ...) +scale_fill_r2dii <- function(colour_labels = NULL, ...) { + discrete_scale("fill", "r2dii", r2dii_pal(colour_labels), ...) } -r2dii_pal <- function(labels = NULL) { - abort_if_unknown_values(labels, palette_colours, column = "label") - r2dii_pal_impl(labels, column = "label", data = palette_colours) +r2dii_pal <- function(colour_labels = NULL) { + abort_if_unknown_values(colour_labels, palette_colours, column = "label") + r2dii_pal_impl(colour_labels, column = "label", data = palette_colours) } diff --git a/man/scale_colour_r2dii.Rd b/man/scale_colour_r2dii.Rd index 1679acfa..896a497d 100644 --- a/man/scale_colour_r2dii.Rd +++ b/man/scale_colour_r2dii.Rd @@ -6,14 +6,14 @@ \alias{scale_fill_r2dii} \title{Custom 2DII colour and fill scales} \usage{ -scale_colour_r2dii(labels = NULL, ...) +scale_colour_r2dii(colour_labels = NULL, ...) -scale_fill_r2dii(labels = NULL, ...) +scale_fill_r2dii(colour_labels = NULL, ...) } \arguments{ -\item{labels}{A character vector. Specifies colour labels to use and their +\item{colour_labels}{A character vector. Specifies colour labels to use and their order. Run \code{unique(r2dii.plot:::palette_colours$label)} to see available -labels. Similar to \code{value} parameter in \code{\link[ggplot2:scale_manual]{ggplot2::scale_colour_manual()}}.} +colours. Similar to \code{value} parameter in \code{\link[ggplot2:scale_manual]{ggplot2::scale_colour_manual()}}.} \item{...}{Other parameters passed on to \code{\link[ggplot2:discrete_scale]{ggplot2::discrete_scale()}}.} } diff --git a/tests/testthat/_snaps/scale_colour_r2dii.md b/tests/testthat/_snaps/scale_colour_r2dii.md index 21e83c43..521044f0 100644 --- a/tests/testthat/_snaps/scale_colour_r2dii.md +++ b/tests/testthat/_snaps/scale_colour_r2dii.md @@ -1,6 +1,6 @@ # if with bad `labels` errors gracefully - Each value of `labels` must be one of these: + Each value of `colour_labels` must be one of these: dark_blue, green, orange, grey, dark_purple, yellow, soft_blue, ruby_red, moss_green. x You passed: bad. i Do you need to see valid values in this dataset?: @@ -8,7 +8,7 @@ --- - Each value of `labels` must be one of these: + Each value of `colour_labels` must be one of these: dark_blue, green, orange, grey, dark_purple, yellow, soft_blue, ruby_red, moss_green. x You passed: bad. i Do you need to see valid values in this dataset?: diff --git a/tests/testthat/test-scale_colour_r2dii.R b/tests/testthat/test-scale_colour_r2dii.R index 042ebfd8..6ee1a850 100644 --- a/tests/testthat/test-scale_colour_r2dii.R +++ b/tests/testthat/test-scale_colour_r2dii.R @@ -6,8 +6,8 @@ test_that("outputs a gg ScaleDiscrete", { }) test_that("if with bad `labels` errors gracefully", { - expect_snapshot_error(scale_colour_r2dii(labels = c("bad"))) - expect_snapshot_error(scale_fill_r2dii(labels = c("bad"))) + expect_snapshot_error(scale_colour_r2dii(colour_labels = c("bad"))) + expect_snapshot_error(scale_fill_r2dii(colour_labels = c("bad"))) }) test_that("changes the plot colours as expected", { @@ -29,3 +29,77 @@ test_that("changes the plot fill as expected", { expect_false(identical(colours_default, colours_changed)) }) + +test_that("with data having specific level factors, scales colours as expected + (#527)", { + + skip_if(r_version_is_older_than(4)) + data <- filter(sda, sector == "cement", region == "global") + + input_levels <- c( + "projected", + "corporate_economy", + "target_demo", + "adjusted_scenario_demo" + ) + + input_color_scale <- c( + "dark_blue", + "green", + "grey", + "ruby_red" + ) + + input_color_scale_hex <- data.frame(label = input_color_scale) %>% + left_join(palette_colours, by = "label") %>% + pull(hex) + + expected_output <- data.frame( + levels = input_levels, + hex = input_color_scale_hex + ) + + data <- data %>% + dplyr::mutate( + emission_factor_metric = factor( + .data$emission_factor_metric, + levels = input_levels + ) + ) + + p <- suppressWarnings( + plot_emission_intensity(data), + classes = "lifecycle_warning_deprecated" + ) + p <- p + scale_colour_r2dii( + colour_labels = input_color_scale, + labels = input_levels + ) + + # print the levels that colours are applied to + ordered_output_levels <- levels(p$data$emission_factor_metric) + + # print the actual colour scales of the plot + ordered_output_colour_scale <- p$scales$get_scales("colour")$palette( + length(ordered_output_levels) + ) + + plot_output <- data.frame( + levels = ordered_output_levels, + hex = ordered_output_colour_scale + ) + + out <- left_join( + plot_output, + expected_output, + by = "levels", + suffix = c("_out", "_expected") + ) %>% + split(.$levels) + + expect_equal(out$projected$hex_out, out$projected$hex_expected) + expect_equal(out$corporate_economy$hex_out, out$corporate_economy$hex_expected) + expect_equal(out$target_demo$hex_out, out$target_demo$hex_expected) + expect_equal(out$adjusted_scenario_demo$hex_out, out$adjusted_scenario_demo$hex_expected) + +})