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

Update diag convenience methods #449

Merged
merged 1 commit into from
May 7, 2020
Merged

Update diag convenience methods #449

merged 1 commit into from
May 7, 2020

Conversation

paultyng
Copy link
Contributor

@paultyng paultyng commented May 6, 2020

No description provided.

@paultyng paultyng added this to the v2.0.0 milestone May 6, 2020
@paultyng paultyng changed the title Update diag convienence methods Update diag convenience methods May 6, 2020
@paultyng paultyng force-pushed the diag branch 2 times, most recently from 6ac2dfc to 9309fb0 Compare May 6, 2020 19:49
// No configuration
if p.ConfigureFunc == nil && p.ConfigureContextFunc == nil {
return diags
return nil
Copy link
Contributor Author

@paultyng paultyng May 6, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I swapped some of these back, I think returning nil when possible is more clear that its not a potential error case. Preserving the go idioms if possible is still useful. When someone does have warnings or are propagating from diag aware functions, the top level diags and appends make sense, but otherwise, I think it may be more effort and compromises on clarity.

helper/schema/resource.go Outdated Show resolved Hide resolved
// if err != nil {
// return diag.FromErr(err)
// }
func FromErr(err error) Diagnostics {
Copy link
Contributor

@appilon appilon May 6, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Overall I do like this pattern, however I would still like a convenience to create a singular Diagnostic from an error. Would it be crazy to keep the helpers for creating on a single diag, but then have a helper to quickly convert to the collection?

return diag.FromErr(err).ToDiags()

Copy link
Contributor

@appilon appilon May 6, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's valuable in scenarios where we have gathered warnings, and encounter a function that just returns a go error

if err != nil {
    return append(diags, diag.FromErr(err))
}

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think the thing is, that you are burdening the 80% case for the 20% case, and you could easily rewrite that second one as:

if err != nil {
    return append(diags, diag.FromErr(err)...)
}

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I wish the package was called diags with this model, but that would collide with calling your slice diags.

@paultyng paultyng merged commit e86af97 into master May 7, 2020
@paultyng paultyng deleted the diag branch May 7, 2020 00:30
@ghost
Copy link

ghost commented Jun 6, 2020

I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues.

If you have found a problem that seems similar to this, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further.

@ghost ghost locked and limited conversation to collaborators Jun 6, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants