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

fix: --base-dir is disregarded in sam build #2718

Merged
merged 6 commits into from
Mar 16, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
fix: build_dir is disregarded in sam build
  • Loading branch information
aahung committed Mar 16, 2021
commit 02b3ae8edabaaa5eee6a4dc005b6aa09eb74fffd
8 changes: 6 additions & 2 deletions samcli/commands/build/build_context.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,10 @@ def __init__(
self._resource_identifier = resource_identifier
self._template_file = template_file
self._base_dir = base_dir

# Note(xinhol): use_raw_codeuri is temporary to fix a bug, and will be removed for a permanent solution.
self._use_raw_codeuri = bool(self._base_dir)

self._build_dir = build_dir
self._cache_dir = cache_dir
self._manifest_path = manifest_path
Expand Down Expand Up @@ -80,8 +84,8 @@ def __enter__(self) -> "BuildContext":
"\n".join([f"- {full_path}" for full_path in remote_stack_full_paths]),
)

self._function_provider = SamFunctionProvider(self.stacks)
self._layer_provider = SamLayerProvider(self.stacks)
self._function_provider = SamFunctionProvider(self.stacks, self._use_raw_codeuri)
Copy link
Contributor

Choose a reason for hiding this comment

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

Could we add a note here too and reference the issue number.

self._layer_provider = SamLayerProvider(self.stacks, self._use_raw_codeuri)

if not self._base_dir:
# Base directory, if not provided, is the directory containing the template
Expand Down
59 changes: 37 additions & 22 deletions samcli/lib/providers/sam_function_provider.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,9 @@ class SamFunctionProvider(SamBaseProvider):
It may or may not contain a function.
"""

def __init__(self, stacks: List[Stack], ignore_code_extraction_warnings: bool = False) -> None:
def __init__(
self, stacks: List[Stack], use_raw_codeuri: bool = False, ignore_code_extraction_warnings: bool = False
) -> None:
"""
Initialize the class with SAM template data. The SAM template passed to this provider is assumed
to be valid, normalized and a dictionary. It should be normalized by running all pre-processing
Expand All @@ -35,6 +37,8 @@ def __init__(self, stacks: List[Stack], ignore_code_extraction_warnings: bool =
You need to explicitly update the class with new template, if necessary.

:param dict stacks: List of stacks functions are extracted from
:param bool use_raw_codeuri: Do not resolve adjust core_uri based on the template path, use the raw uri.
Note(xinhol): use_raw_codeuri is temporary to fix a bug, and will be removed for a permanent solution.
:param bool ignore_code_extraction_warnings: Ignores Log warnings
"""

Expand All @@ -44,7 +48,9 @@ def __init__(self, stacks: List[Stack], ignore_code_extraction_warnings: bool =
LOG.debug("%d resources found in the stack %s", len(stack.resources), stack.stack_path)

# Store a map of function full_path to function information for quick reference
self.functions = SamFunctionProvider._extract_functions(self.stacks, ignore_code_extraction_warnings)
self.functions = SamFunctionProvider._extract_functions(
self.stacks, use_raw_codeuri, ignore_code_extraction_warnings
)

self._deprecated_runtimes = {"nodejs4.3", "nodejs6.10", "nodejs8.10", "dotnetcore2.0"}
self._colored = Colored()
Expand Down Expand Up @@ -98,12 +104,15 @@ def get_all(self) -> Iterator[Function]:
yield function

@staticmethod
def _extract_functions(stacks: List[Stack], ignore_code_extraction_warnings: bool = False) -> Dict[str, Function]:
def _extract_functions(
stacks: List[Stack], use_raw_codeuri: bool, ignore_code_extraction_warnings: bool
) -> Dict[str, Function]:
"""
Extracts and returns function information from the given dictionary of SAM/CloudFormation resources. This
method supports functions defined with AWS::Serverless::Function and AWS::Lambda::Function

:param stacks: List of SAM/CloudFormation stacks to extract functions from
:param bool use_raw_codeuri: Do not resolve adjust core_uri based on the template path, use the raw uri.
:param bool ignore_code_extraction_warnings: suppress log statements on code extraction from resources.
:return dict(string : samcli.commands.local.lib.provider.Function): Dictionary of function full_path to the
Function configuration object
Expand All @@ -124,13 +133,15 @@ def _extract_functions(stacks: List[Stack], ignore_code_extraction_warnings: boo
layers = SamFunctionProvider._parse_layer_info(
stack,
resource_properties.get("Layers", []),
use_raw_codeuri,
ignore_code_extraction_warnings=ignore_code_extraction_warnings,
)
function = SamFunctionProvider._convert_sam_function_resource(
stack,
name,
resource_properties,
layers,
use_raw_codeuri,
ignore_code_extraction_warnings=ignore_code_extraction_warnings,
)
result[function.full_path] = function
Expand All @@ -139,10 +150,11 @@ def _extract_functions(stacks: List[Stack], ignore_code_extraction_warnings: boo
layers = SamFunctionProvider._parse_layer_info(
stack,
resource_properties.get("Layers", []),
use_raw_codeuri,
ignore_code_extraction_warnings=ignore_code_extraction_warnings,
)
function = SamFunctionProvider._convert_lambda_function_resource(
stack, name, resource_properties, layers
stack, name, resource_properties, layers, use_raw_codeuri
)
result[function.full_path] = function

Expand All @@ -156,6 +168,7 @@ def _convert_sam_function_resource(
name: str,
resource_properties: Dict,
layers: List[LayerVersion],
use_raw_codeuri: bool,
ignore_code_extraction_warnings: bool = False,
) -> Function:
"""
Expand Down Expand Up @@ -196,18 +209,12 @@ def _convert_sam_function_resource(
LOG.debug("Found Serverless function with name='%s' and ImageUri='%s'", name, imageuri)

return SamFunctionProvider._build_function_configuration(
stack,
name,
codeuri,
resource_properties,
layers,
inlinecode,
imageuri,
stack, name, codeuri, resource_properties, layers, inlinecode, imageuri, use_raw_codeuri
)

@staticmethod
def _convert_lambda_function_resource(
stack: Stack, name: str, resource_properties: Dict, layers: List[LayerVersion]
stack: Stack, name: str, resource_properties: Dict, layers: List[LayerVersion], use_raw_codeuri: bool
) -> Function:
"""
Converts a AWS::Lambda::Function resource to a Function configuration usable by the provider.
Expand All @@ -220,6 +227,8 @@ def _convert_lambda_function_resource(
Properties of this resource
layers List(samcli.commands.local.lib.provider.Layer)
List of the Layer objects created from the template and layer list defined on the function.
use_raw_codeuri
Do not resolve adjust core_uri based on the template path, use the raw uri.

Returns
-------
Expand Down Expand Up @@ -250,13 +259,7 @@ def _convert_lambda_function_resource(
LOG.debug("Found Lambda function with name='%s' and Imageuri='%s'", name, imageuri)

return SamFunctionProvider._build_function_configuration(
stack,
name,
codeuri,
resource_properties,
layers,
inlinecode,
imageuri,
stack, name, codeuri, resource_properties, layers, inlinecode, imageuri, use_raw_codeuri
)

@staticmethod
Expand All @@ -268,6 +271,7 @@ def _build_function_configuration(
layers: List,
inlinecode: Optional[str],
imageuri: Optional[str],
use_raw_codeuri: bool,
) -> Function:
"""
Builds a Function configuration usable by the provider.
Expand All @@ -282,18 +286,23 @@ def _build_function_configuration(
Properties of this resource
layers List(samcli.commands.local.lib.provider.Layer)
List of the Layer objects created from the template and layer list defined on the function.
use_raw_codeuri
Do not resolve adjust core_uri based on the template path, use the raw uri.

Returns
-------
samcli.commands.local.lib.provider.Function
Function configuration
"""
metadata = resource_properties.get("Metadata", None)
if metadata and "DockerContext" in metadata:
if metadata and "DockerContext" in metadata and not use_raw_codeuri:
metadata["DockerContext"] = SamLocalStackProvider.normalize_resource_path(
stack.location, metadata["DockerContext"]
)

if codeuri and not use_raw_codeuri:
codeuri = SamLocalStackProvider.normalize_resource_path(stack.location, codeuri)

return Function(
stack_path=stack.stack_path,
name=name,
Expand All @@ -303,7 +312,7 @@ def _build_function_configuration(
memory=resource_properties.get("MemorySize"),
timeout=resource_properties.get("Timeout"),
handler=resource_properties.get("Handler"),
codeuri=SamLocalStackProvider.normalize_resource_path(stack.location, codeuri) if codeuri else None,
codeuri=codeuri,
imageuri=imageuri if imageuri else resource_properties.get("ImageUri"),
imageconfig=resource_properties.get("ImageConfig"),
environment=resource_properties.get("Environment"),
Expand All @@ -319,6 +328,7 @@ def _build_function_configuration(
def _parse_layer_info(
stack: Stack,
list_of_layers: List[Any],
use_raw_codeuri: bool,
ignore_code_extraction_warnings: bool = False,
) -> List[LayerVersion]:
"""
Expand All @@ -331,6 +341,8 @@ def _parse_layer_info(
list_of_layers : List[Any]
List of layers that are defined within the Layers Property on a function,
layer can be defined as string or Dict, in case customers define it in other types, use "Any" here.
use_raw_codeuri : bool
Do not resolve adjust core_uri based on the template path, use the raw uri.
ignore_code_extraction_warnings : bool
Whether to print warning when codeuri is not a local pth

Expand Down Expand Up @@ -390,10 +402,13 @@ def _parse_layer_info(
layer_logical_id, layer_properties, "ContentUri", ignore_code_extraction_warnings
)

if codeuri and not use_raw_codeuri:
codeuri = SamLocalStackProvider.normalize_resource_path(stack.location, codeuri)
mndeveci marked this conversation as resolved.
Show resolved Hide resolved

layers.append(
LayerVersion(
layer_logical_id,
SamLocalStackProvider.normalize_resource_path(stack.location, codeuri) if codeuri else None,
codeuri,
compatible_runtimes,
layer_resource.get("Metadata", None),
stack_path=stack.stack_path,
Expand Down
10 changes: 8 additions & 2 deletions samcli/lib/providers/sam_layer_provider.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ class SamLayerProvider(SamBaseProvider):
It may or may not contain a layer.
"""

def __init__(self, stacks: List[Stack]) -> None:
def __init__(self, stacks: List[Stack], use_raw_codeuri: bool = False) -> None:
"""
Initialize the class with SAM template data. The SAM template passed to this provider is assumed
to be valid, normalized and a dictionary. It should be normalized by running all pre-processing
Expand All @@ -34,8 +34,11 @@ def __init__(self, stacks: List[Stack]) -> None:
Parameters
----------
:param dict stacks: List of stacks layers are extracted from
:param bool use_raw_codeuri: Do not resolve adjust core_uri based on the template path, use the raw uri.
Note(xinhol): use_raw_codeuri is temporary to fix a bug, and will be removed for a permanent solution.
"""
self._stacks = stacks
self._use_raw_codeuri = use_raw_codeuri

self._layers = self._extract_layers()

Expand Down Expand Up @@ -102,9 +105,12 @@ def _convert_lambda_layer_resource(self, stack: Stack, layer_logical_id: str, la
if resource_type == self.LAMBDA_LAYER:
codeuri = SamLayerProvider._extract_lambda_function_code(layer_properties, "Content")

if codeuri and not self._use_raw_codeuri:
codeuri = SamLocalStackProvider.normalize_resource_path(stack.location, codeuri)
mndeveci marked this conversation as resolved.
Show resolved Hide resolved

return LayerVersion(
layer_logical_id,
SamLocalStackProvider.normalize_resource_path(stack.location, codeuri) if codeuri else None,
codeuri,
compatible_runtimes,
layer_resource.get("Metadata", None),
stack_path=stack.stack_path,
Expand Down