Hello. I am using the codedeploy orb to deploy my application to AWS and instead of hardcoding the values in there like application-name etc, i am trying to pass variables instead but the orb doesn’t seem to be respecting the variables.
The run command executes a shell, so any work done within the shell is local to the shell, so any environment variables defined, delete or modified within the shell only affect the shell’s environment and are lost once the shell returns.
There are well-known workarounds for shell-to-shell variable passing, but I’m not sure how you would pass the variable up from the shell to the circleci environment, hopefully, someone else has that answer.
but i’m running into An error occurred (InvalidApplicationNameException) when calling the CreateDeployment operation: Application name contains invalid characters.
Removing quotes around deployment-config won’t help if i’m running into this : No application found for name: my-app- -application You can see in this error the ${stage} is still being set as blank. Thanks for looking into it.
OK, then we are back to the issue of environment variables not being available to the circleci application if they are created by steps being run by the circleci application.
If you must have the username converted to lowercase, have you considered just copying the code for the deploy-bundle part of the orb and making the change within its run command?
One possible option is to use “parameters” of a command to pass into a step, it just means you may need to shoe-horn in a command in your config. Meaning, from your workflow, call a command with a parameter, then in the command, use the parameter to set an environment variable that your step will use?
For example, my team has examples like this:
commands:
check-security:
parameters:
component_name:
type: string
description: "A component name to use when searching for security related issues."
steps:
- run:
name: Add security issues as PR comment
environment:
COMPONENT_NAME: << parameters.component_name >>
command: ./scripts/perform-some-steps.sh
And that command is called from another job in a workflow like: