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

add_resource(replace = TRUE) fails silently if resource does not exist #259

Open
Rafnuss opened this issue Aug 28, 2024 · 4 comments
Open
Labels
function:add/remove Functions add_resource(), remove_resource()
Milestone

Comments

@Rafnuss
Copy link

Rafnuss commented Aug 28, 2024

Hi,
Is this desired? I would expect that replace=TRUE should not prevent the addition of a new (non-yet-exisiting) resource.

library(frictionless)

package <- example_package()

# Create a data frame
df <- data.frame(
  multimedia_id = c(
    "aed5fa71-3ed4-4284-a6ba-3550d1a4de8d",
    "da81a501-8236-4cbd-aa95-4bc4b10a05df"
  ),
  x = c(718, 748),
  y = c(860, 900)
)

# Add the resource "positions" from the data frame
add_resource(package, "positions", data = df)
#> A Data Package with 4 resources:
#> • deployments
#> • observations
#> • media
#> • positions
#> Use `unclass()` to print the Data Package as a list.

add_resource(package, "positions", data = df, replace = TRUE)
#> A Data Package with 3 resources:
#> • deployments
#> • observations
#> • media
#> Use `unclass()` to print the Data Package as a list.

I didn't look at the function, so not sure why this is happening.

@Rafnuss Rafnuss changed the title replace=TRUE` prevent the addition of a new resource replace=TRUE prevent the addition of a new resource Aug 28, 2024
@peterdesmet
Copy link
Member

peterdesmet commented Aug 28, 2024

You didn't assign your first add_resource() to package (it is not updated in place). So the following works:

library(frictionless)
package <- example_package()

# Create a data frame
df <- data.frame(
  multimedia_id = c(
    "aed5fa71-3ed4-4284-a6ba-3550d1a4de8d",
    "da81a501-8236-4cbd-aa95-4bc4b10a05df"
  ),
  x = c(718, 748),
  y = c(860, 900)
)

package <- add_resource(package, "positions", data = df)

add_resource(package, "positions", data = df, replace = TRUE)
#> A Data Package with 4 resources:
#> • deployments
#> • observations
#> • media
#> • positions
#> Use `unclass()` to print the Data Package as a list.

Created on 2024-08-28 with reprex v2.1.0

However - and I'm not sure that this is what you wanted to point out - if you replace a resource that is not there, then nothing happens. It's probably better if:

  1. add_resource() just adds the resource then
  2. Or alternatively, add_resource() returns an error to say it can't find the resource

I prefer the latter.

@peterdesmet peterdesmet changed the title replace=TRUE prevent the addition of a new resource add_resource(replace = TRUE) fails silently if resource does not exist Aug 28, 2024
@peterdesmet peterdesmet added the function:add/remove Functions add_resource(), remove_resource() label Aug 28, 2024
@peterdesmet peterdesmet modified the milestones: 1.2.0, 1.3.0 Aug 28, 2024
@Rafnuss
Copy link
Author

Rafnuss commented Aug 28, 2024

Yes, that's what I wanted to show (it works without Replace=T but fail with it).

Ok, I personally prefer the traditional overwrite=FALSE, which allows the modification even if the element does not exist. But up to you!

@peterdesmet
Copy link
Member

Changed my mind, I agree that overwrite = TRUE should mainly be used to avoid overwriting resources by accident. It can silently add the resource if it isn't there yet.

Rafnuss added a commit to Rafnuss/frictionless-r that referenced this issue Dec 28, 2024
@Rafnuss
Copy link
Author

Rafnuss commented Jan 13, 2025

What about the case where you might want to literally add data to an exsiting resources (i.e., with a bind_rows()). Should this be part of the scope of this function?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
function:add/remove Functions add_resource(), remove_resource()
Projects
None yet
Development

No branches or pull requests

2 participants