[ 
https://issues.apache.org/jira/browse/ARROW-14712?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

ASF GitHub Bot updated ARROW-14712:
-----------------------------------
    Labels: pull-request-available  (was: )

> [R] compare_dplyr_error() too strict
> ------------------------------------
>
>                 Key: ARROW-14712
>                 URL: https://issues.apache.org/jira/browse/ARROW-14712
>             Project: Apache Arrow
>          Issue Type: Improvement
>          Components: R
>            Reporter: Romain Francois
>            Priority: Major
>              Labels: pull-request-available
>          Time Spent: 10m
>  Remaining Estimate: 0h
>
> dplyr errors are about to be updated and so the mechanism used by 
> compare_dplyr_error() fails:
> I'm seeing this on the revdeps :
> {{══ Failed tests 
> ════════════════════════════════════════════════════════════════}}
> {{── Error (test-dplyr-filter.R:263:3): filter environment scope 
> ─────────────────}}
> {{Error in `lapply(args, function(x) {}}
> {{{}if (!inherits(x, "Expression")){}}}{{{}{ x <- Expression$scalar(x) 
> }{}}}{{{}x{}}}
> {{})`: object 'b_var' not found}}
> {{Backtrace:}}
> {{▆}}
> {{1. ├─arrow:::expect_dplyr_error(input %>% filter(chr == b_var), tbl) at 
> test-dplyr-filter.R:263:2}}
> {{2. │ ├─testthat::expect_error(...) at 
> tests/testthat/helper-expectation.R:158:2}}
> {{3. │ │ └─testthat:::expect_condition_matching(...)}}
> {{4. │ │ └─testthat:::quasi_capture(...)}}
> {{5. │ │ ├─testthat .capture(...)}}
> {{6. │ │ │ └─base::withCallingHandlers(...)}}
> {{7. │ │ └─rlang::eval_bare(quo_get_expr(.quo), quo_get_env(.quo))}}
> {{8. │ └─rlang::eval_tidy(expr, rlang::new_data_mask(rlang::env(input = 
> record_batch(tbl))))}}
> {{9. ├─input %>% filter(chr == b_var)}}
> {{10. ├─dplyr::filter(., chr == b_var)}}
> {{11. └─arrow:::filter.ArrowTabular(., chr == b_var)}}
> {{12. └─base::lapply(filts, arrow_eval, arrow_mask(.data))}}
> {{13. └─arrow FUN(X[[i]], ...)}}
> {{14. └─base::tryCatch(...)}}
> {{15. └─base tryCatchList(expr, classes, parentenv, handlers)}}
> {{16. └─base tryCatchOne(expr, names, parentenv, handlers[[1L]])}}
> {{{}17. └─value[[3L]](cond){}}}{{{}[ FAIL 1 | WARN 3 | SKIP 58 | PASS 5783 
> ]{}}}
> {{Error: Test failures}}
> {{{}Execution halted{}}}{{{}1 error x | 0 warnings ✓ | 1 note x{}}}
>  
> here's a reprex showing what's happening: 
> {{``` r}}
> {{library(dplyr, warn.conflicts = FALSE)}}
> {{{}library(arrow, warn.conflicts = FALSE){}}}{{{}E <- function(expr) \{ 
> tryCatch(expr, error = function(cnd) print(cnd, backtrace = 
> FALSE))}{}}}{{{}tbl <- tibble::tibble({}}}
> {{  chr = letters[c(1:5, NA, 7:10)]}}
> {{{}){}}}{{{}E({}}}
> {{  tbl %>% }}
> {{    filter(chr == b_var)}}
> {{)}}
> {{#> <error/rlang_error>}}
> {{#> Error in `filter()`:}}
> {{#>   Problem while computing `..1 = chr == b_var`.}}
> {{#> Caused by error:}}
> {{#>   object 'b_var' not found}}
> {{E(}}
> {{  record_batch(tbl) %>% }}
> {{    filter(chr == b_var)}}
> {{)}}
> {{#> <simpleError in lapply(args, function(x) \{    if (!inherits(x, 
> "Expression")) {        x <- Expression$scalar(x)    }    x}): object 'b_var' 
> not found>}}
> {{{}```{}}}{{{}<sup>Created on 2021-11-15 by the [reprex 
> package](https://reprex.tidyverse.org) (v2.0.1.9000)</sup>{}}}



--
This message was sent by Atlassian Jira
(v8.20.1#820001)

Reply via email to