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

Re-applying fails for non-existent output being parsed as JSON #3

Closed
yaronya opened this issue Feb 17, 2022 · 11 comments
Closed

Re-applying fails for non-existent output being parsed as JSON #3

yaronya opened this issue Feb 17, 2022 · 11 comments
Labels
bug Something isn't working

Comments

@yaronya
Copy link

yaronya commented Feb 17, 2022

Getting this error (during plan) when applying an existing stack:

│ Error: Error in function call
│ 
│   on .terraform/modules/stack.enable_asg_metrics_collection/output.tf line 3, in output "result":
│    3:   value       = jsondecode(data.local_file.awscli_results_file.content)
│     ├────────────────
│     │ data.local_file.awscli_results_file.content is ""
│ 
│ Call to function "jsondecode" failed: EOF.

Deleting the .terraform/modules/stack.enable_asg_metrics_collection folder or re-running terraform init --upgrade (which removes the folder) is the workaround I'm current doing, but how can I overcome this in a better way?
I would've expected the module to not jsondecode in case there is no output...

@rquadling
Copy link
Member

Interesting. What is the AWS CLI call you're making and what output is generated?

To date, all our use cases have been to retrieve known data.

@rquadling
Copy link
Member

And apologies for not responding earlier.

@rquadling
Copy link
Member

OOI, is your local environment configured such that JSON is not the default output of the AWS CLI? (See #2 which I'm about to release).

@rquadling
Copy link
Member

I've have managed to replicate the issue in our own setup! So thank you for the report. Hopefully the fix I'm about to release will work for us. Hopefully it'll work for you also.

rquadling added a commit that referenced this issue May 26, 2022
In the use case documented in the README.md, if there are multiple ASGs,
and this module is then called iteratively, each iteration will now
correctly have its own output.

This may also be fixing #3.

In local testing, for a new ASG being added to a pool of existing ASGs,
the recorded output files are showing the correct values, with the string
null being recorded for the new ASG (which is correct in this context).
@rquadling
Copy link
Member

Hi. I've just released https://github.com/digitickets/terraform-aws-cli/releases/tag/v5.0.2. I'd be very grateful if you could see if this release fixes the issue you're facing.

@pavkar
Copy link

pavkar commented May 31, 2022

I have the same problem. I use version 5.0.2. I'm trying to update service settings and command does not have a response body. As stated in documentation "If the action is successful, the service sends back an HTTP 200 response with an empty HTTP body.". Response is in JSON.

@rquadling
Copy link
Member

Can you send me the module resource you're using please? Hopefully with that, I can replicate the issue and provide a solution.

@rquadling rquadling added the bug Something isn't working label May 31, 2022
@pavkar
Copy link

pavkar commented May 31, 2022

https://awscli.amazonaws.com/v2/documentation/api/latest/reference/guardduty/update-detector.html
Example of the command:
aws guardduty update-detector --finding-publishing-frequency ONE_HOUR

@rquadling
Copy link
Member

So, is the issue that you've not supplied a --detector-id?

$ aws guardduty update-detector --finding-publishing-frequency ONE_HOUR

usage: aws [options] <command> <subcommand> [<subcommand> ...] [parameters]
To see help text, you can run:

  aws help
  aws <command> help
  aws <command> <subcommand> help

aws: error: the following arguments are required: --detector-id

So tracking errors from the AWS CLI and reporting that back is what's needed.

@pavkar
Copy link

pavkar commented May 31, 2022

Sorry I didn't add it into the example I am using this syntax:
aws guardduty --detector-id XXXXXXXXXXXXXXXXXX update-detector --finding-publishing-frequency ONE_HOUR

@rquadling
Copy link
Member

rquadling commented May 31, 2022

Thank you for that. Replicated. It does seem that Terraform already supports this (https://registry.terraform.io/providers/hashicorp/aws/latest/docs/resources/guardduty_detector#finding_publishing_frequency).

But having replicated the issue using your example, I think the fix is relatively simple.

I've documented a new test that demonstrates the fix.

Releasing v5.0.3 shortly.

rquadling added a commit that referenced this issue May 31, 2022
- Fix for when the AWS call being made has no output (which is invalid JSON). Thank you [Yaron Yarimi and Pavel Kargin](#3)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants