Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

tests failing #1139

Closed
nunotexbsd opened this issue Oct 5, 2023 · 7 comments
Closed

tests failing #1139

nunotexbsd opened this issue Oct 5, 2023 · 7 comments

Comments

@nunotexbsd
Copy link

FreeBSD 13.2 /R 4.3.1

R version 4.3.1 (2023-06-16) -- "Beagle Scouts"
Copyright (C) 2023 The R Foundation for Statistical Computing
Platform: amd64-portbld-freebsd13.2 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library(testthat)
> library(lubridate)
Warning: Your system is mis-configured: '/var/db/timezone/localtime' is not a symlink
Warning: '/var/db/timezone/localtime' is not identical to any known timezone file

Attaching package: 'lubridate'

The following objects are masked from 'package:base':

    date, intersect, setdiff, union

>
> test_check("lubridate")
[ FAIL 5 | WARN 3 | SKIP 11 | PASS 3027 ]

== Skipped tests (11) ==========================================================
* FIXME: activate when timechange#29 isfixed (1): 'test-periods.R:650:3'
* FIXME: time_length should be same on sides of DST? (1):
  'test-timespans.R:55:3'
* FIXME: ymd_hms OSz parsing (2): 'test-parsers.R:263:3',
  'test-parsers.R:278:3'
* On CRAN (7): 'test-namespace.R:33:3', 'test-namespace.R:44:3',
  'test-ops-integer-division.R:17:3', 'test-parsers.R:1122:3',
  'test-parsers.R:1141:3', 'test-pretty.R:4:3', 'test-vctrs.R:549:3'

== Failed tests ================================================================
-- Error ('test-Dates.R:15:3'): as_date works ----------------------------------
Error in `as.POSIXlt.character(x, tz, ...)`: character string is not in a standard unambiguous format
Backtrace:
    x
 1. +-base::as.POSIXct("2010-08-03 00:59:59.23") at test-Dates.R:15:2
 2. \-base::as.POSIXct.default("2010-08-03 00:59:59.23")
 3.   +-base::as.POSIXct(as.POSIXlt(x, tz, ...), tz, ...)
 4.   +-base::as.POSIXlt(x, tz, ...)
 5.   \-base::as.POSIXlt.character(x, tz, ...)
-- Failure ('test-accessors.R:480:3'): date accessor extracts correct date -----
date(posct) (`actual`) not equal to as.Date("2010-02-03") (`expected`).

`actual`:   NA
`expected`: "2010-02-03"
-- Error ('test-format_ISO8601.R:35:3'): Formatting a datetime works -----------
Error in `h(simpleError(msg, call))`: error in evaluating the argument 'x' in selecting a method for function 'format_ISO8601': character string is not in a standard unambiguous format
Backtrace:
     x
  1. +-testthat::expect_equal(...) at test-format_ISO8601.R:35:2
  2. | \-testthat::quasi_label(enquo(object), label, arg = "object")
  3. |   \-rlang::eval_bare(expr, quo_get_env(quo))
  4. +-lubridate::format_ISO8601(as.POSIXct("2018-02-01 03:04:05", tz = "EST"))
  5. +-base::as.POSIXct("2018-02-01 03:04:05", tz = "EST")
  6. +-base::as.POSIXct.default("2018-02-01 03:04:05", tz = "EST")
  7. | +-base::as.POSIXct(as.POSIXlt(x, tz, ...), tz, ...)
  8. | +-base::as.POSIXlt(x, tz, ...)
  9. | \-base::as.POSIXlt.character(x, tz, ...)
 10. |   \-base::stop("character string is not in a standard unambiguous format")
 11. \-base::.handleSimpleError(...)
 12.   \-base (local) h(simpleError(msg, call))
-- Error ('test-intervals.R:803:3'): %% on interval uses m+ arithmetic ---------
Error in `as.POSIXlt.character(x, tz, ...)`: character string is not in a standard unambiguous format
Backtrace:
    x
 1. +-base::as.POSIXct(start) at test-intervals.R:803:2
 2. \-base::as.POSIXct.default(start)
 3.   +-base::as.POSIXct(as.POSIXlt(x, tz, ...), tz, ...)
 4.   +-base::as.POSIXlt(x, tz, ...)
 5.   \-base::as.POSIXlt.character(x, tz, ...)
-- Error ('test-ops-compare.R:2:3'): Comparison operators work with POSIX and Date objects --
Error in `as.POSIXlt.character(x, tz, ...)`: character string is not in a standard unambiguous format
Backtrace:
    x
 1. +-testthat::expect_true(...) at test-ops-compare.R:2:2
 2. | \-testthat::quasi_label(enquo(object), label, arg = "object")
 3. |   \-rlang::eval_bare(expr, quo_get_env(quo))
 4. \-lubridate (local) `==.POSIXt`(ymd_hms("2016-01-03 00:00:00", tz = ""), "2016-01-03 00:00:00")
 5.   +-base::as.POSIXct(e2)
 6.   \-base::as.POSIXct.default(e2)
 7.     +-base::as.POSIXct(as.POSIXlt(x, tz, ...), tz, ...)
 8.     +-base::as.POSIXlt(x, tz, ...)
 9.     \-base::as.POSIXlt.character(x, tz, ...)

[ FAIL 5 | WARN 3 | SKIP 11 | PASS 3027 ]
Error: Test failures
Execution halted

Any clues?
Thanks

@vspinu
Copy link
Member

vspinu commented Oct 5, 2023

No idea, was it working with the older version?

As the message suggests your tzone database might not be in the location as suggested. Our tzone db lookup is here Very simple code, you can see what's going on by yourself. If your problem is generic then a PR would be very much appreciated. Thanks!

@vspinu
Copy link
Member

vspinu commented Oct 5, 2023

Our results are good on debian and fedora, so if indeed an issue it's FreeBSD specific.

@nunotexbsd
Copy link
Author

@vspinu

It seems that some canonical TZs originates the error, EST in tests.
Any clue about it? Maybe a R configuration that needs be fixed?

Attaching package: ‘lubridate’

The following objects are masked from ‘package:base’:

    date, intersect, setdiff, union

> format_ISO8601(as.POSIXct("2018-02-01 03:04:05", tz = "EST"), usetz = TRUE)
Error in h(simpleError(msg, call)) :
  error in evaluating the argument 'x' in selecting a method for function 'format_ISO8601': character string is not in a standard unambiguous format

> format_ISO8601(as.POSIXct("2018-02-01 03:04:05", tz = "Europe/Lisbon"), usetz = TRUE)
[1] "2018-02-01T03:04:05+0000"

> format_ISO8601(as.POSIXct("2018-02-01 03:04:05", tz = "GMT"), usetz = TRUE)
[1] "2018-02-01T03:04:05+0000"

> format_ISO8601(as.POSIXct("2018-02-01 03:04:05", tz = "MET"), usetz = TRUE)
[1] "2018-02-01T03:04:05+0100"

@vspinu
Copy link
Member

vspinu commented Oct 8, 2023

Sorry, I misread. This is R base error and not lubridate specific. Strange for sure. It's probably tzone database related but the error is confusing. It might be worth reporting this to R folks.

  6. +-base::as.POSIXct.default("2018-02-01 03:04:05", tz = "EST")
  7. | +-base::as.POSIXct(as.POSIXlt(x, tz, ...), tz, ...)
  8. | +-base::as.POSIXlt(x, tz, ...)
  9. | \-base::as.POSIXlt.character(x, tz, ...)
 10. |   \-base::stop("character string is not in a standard unambiguous format")

@Jehops
Copy link

Jehops commented Oct 10, 2023

I see this when calling Sys.timezone().

> Sys.timezone()
Warning: Your system is mis-configured: ‘/etc/localtime’ is not a symlink
Warning: It is strongly recommended to set envionment variable TZ to ‘America/Halifax’ (or equivalent)
[1] "America/Halifax"

On FreeBSD /etc/localtime isn't a symlink, but a copy of the timezone file under /usr/share/zoneinfo. When I back up /etc/localtime and create a symlink, there is no warning.

# mv localtime localtime.bak
# ln -s /usr/share/zoneinfo/America/Halifax .
# mv localtime localtime.bak
# ln -s /usr/share/zoneinfo/America/Halifax /etc/localtime
% R --quiet -e "Sys.timezone()"
> Sys.timezone()
[1] "America/Halifax"

@nunotexbsd, do you have /etc/localtime? If so, does it match an entry in the timezone database? You can check with something like find /usr/share/zoneinfo/ -type f -exec cmp -s {} /etc/localtime \; -print;.

@nunotexbsd
Copy link
Author

@Jehops

Hello and sorry for delay!

I'm running in a poudriere jail and /etc/localtime was not exist. I did create a symlink and R shows:

> Sys.timezone()
[1] "Europe/Lisbon"

It doesn't solve the following command (called by test unit):

> library(lubridate)

> format_ISO8601(as.POSIXct("2018-02-01 03:04:05", tz = "EST"), usetz = TRUE)
Error in h(simpleError(msg, call)) :
  error in evaluating the argument 'x' in selecting a method for function 'format_ISO8601':
character string is not in a standard unambiguous format

> format_ISO8601(as.POSIXct("2018-02-01 03:04:05", tz = "GMT"), usetz = TRUE)
[1] "2018-02-01T03:04:05+0000"

> format_ISO8601(as.POSIXct("2018-02-01 03:04:05", tz = "Europe/Lisbon"), usetz = TRUE)
[1] "2018-02-01T03:04:05+0000"

Something wrong with "EST" timezone and it doesn't seems related to system /etc/localtime.

Thanks

@nunotexbsd
Copy link
Author

Hello!

1.9.4 version fixes testunit.

Thanks very much.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants