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

Allow duplicated resources (by name) if at most one is unconditional #15909

Open
wants to merge 6 commits into
base: main
Choose a base branch
from

Conversation

jeskew
Copy link
Contributor

@jeskew jeskew commented Dec 20, 2024

Resolves #1410

There are a couple of updates to this check included as well:

  • The check is also applied to existing resources (since duplicates are not allowed in symbolic name templates)
  • The check is based on the type of the name rather than the syntax, so it will catch duplicates that use a reference or expression
Microsoft Reviewers: Open in CodeFlow

Copy link
Contributor

github-actions bot commented Dec 20, 2024

Test this change out locally with the following install scripts (Action run 12673408832)

VSCode
  • Mac/Linux
    bash <(curl -Ls https://aka.ms/bicep/nightly-vsix.sh) --run-id 12673408832
  • Windows
    iex "& { $(irm https://aka.ms/bicep/nightly-vsix.ps1) } -RunId 12673408832"
Azure CLI
  • Mac/Linux
    bash <(curl -Ls https://aka.ms/bicep/nightly-cli.sh) --run-id 12673408832
  • Windows
    iex "& { $(irm https://aka.ms/bicep/nightly-cli.ps1) } -RunId 12673408832"

Copy link
Contributor

github-actions bot commented Dec 20, 2024

Dotnet Test Results

    78 files   -     39      78 suites   - 39   33m 3s ⏱️ - 16m 42s
11 588 tests  -     20  11 588 ✅  -     19  0 💤 ±0  0 ❌  - 1 
26 908 runs   - 13 431  26 908 ✅  - 13 430  0 💤 ±0  0 ❌  - 1 

Results for commit fd51ea1. ± Comparison against base commit 4fff513.

This pull request removes 1841 and adds 636 tests. Note that renamed tests count towards both.

		nestedProp1: 1
		nestedProp2: 2
		prop1: true
		prop2: false
	1
	2
	\$'")
	prop1: true
	prop2: false
…
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Bicep_compiler_handles_corrupted_extension_package_gracefully (\u001f�\u0008\u0000\u0000\u0000\u0000\u0000\u0000
�Խ
�0\u0010\u0000��>E�\u0003���\u0011:\u0008\u000eV�
��\u0004\u001b�B��\u0015
��� .-.�\u0011�7��p\u0007����F'�(�@\u0008\u0005\u0010���\u0004c��
�$��
\u0001$y��սW��QV����q�\u000f"sOWifB,��LQ� %l.)��ع+��w��%L����Z��&=�J���N���
�D��\u001f\u0011\u0006�\u000c��cJ�\u0004Hp.l��ғ���O?���m�:m\u000e��_xv\u0002O]��8�3�\u0017�;Y\u0000\u000c\u0000\u0000,"'7' is an invalid end of a number. Expected a delimiter. Path: $.INVALID_JSON | LineNumber: 0 | BytePositionInLine: 20.")
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Bicep_compiler_handles_corrupted_extension_package_gracefully (\u001f�\u0008\u0000\u0000\u0000\u0000\u0000\u0000
�Խ\u000e� \u0010\u0007pf���\u0001\u0010z|������\u000f���\u001a[M�I\u0013�K\u0007��ƥ�&�\u001b�\u0002\u0007�\u000f��]�D�aY1�9�2ҷ�*�R��7�4D�\u0017N�QM5�{�ŭ�\u000c�\u000c��\u000fJg��c�\u000ba@��`-\u0003\u0000=\u0003;	s��9a�����XdX�Su)��|�cF\u001d����+���\u000e��?\u0000�\u0012\u0000�!\+eB�\u0007����N�M��\u0015w\u001e�\u0015�[,�9ݻs���{��(���	�O\u0006`\u0000\u000c\u0000\u0000,"Value cannot be null. (Parameter 'source')")
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Bicep_compiler_handles_corrupted_extension_package_gracefully (\u001f�\u0008\u0000\u0000\u0000\u0000\u0000\u0000
��K
�0\u0010\u0006�=EO��t�h\u0016ݻ�
A\u000b>h*}`A���Bp��6���\u0019&�$�<��a[�Cٴ\\u0001@��������\\u001f�D��\u0005\u0018hI��dX|�	}��Ə��Y?(�\u0013۝��@M��!�s"C\u0002�����5L��;\u0016����������P�5��h4�����D��\u000f�1\u0014��D�L���@��U2����?BO\u0010EQ\u0014��\u0004���*\u0000\u000c\u0000\u0000,"The path: index.json was not found in artifact contents")
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Bicep_compiler_handles_corrupted_extension_package_gracefully (\u001f�\u0008\u0000\u0000\u0000\u0000\u0000\u0000\u0003�Խ
�0\u0010\u0007��>E�\u0003ĤI�F��"��\u0000�=�bki*\u0014�w7\u001dĥť\u001f����?܅p!�i�`2�-�<fk��F�H���\u000e\u0013
1�F\u0011URJ�p;�$=�1�\u001be�^?(��i�\u0002\u0012�xą�L\u0013��\u0008�Z�Z:Tc\u001aW�9'y�AK.�Vv�b(��5�\u0001����Ƿ��\ �\u0007p%\u0019\u000f�B4�ҥ�,;������������l\u0007�\u0011�`�O�j��l��y�t^ӵ�\u0014\u0000\u000c\u0000\u0000,"Value cannot be null. (Parameter 'source')")
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Bicep_compiler_handles_corrupted_extension_package_gracefully (\u001f�\u0008\u0000\u0000\u0000\u0000\u0000\u0000\u0003�Խ
�0\u0010\u0007��>E�\u0003�I/\u001fV� 8X�*\u0008�\u0012l�
��V(�\uda58\udcf8���C0�19�\u000b�����z��8)J\u00020g.A}�������BL�QD�\u0010\u0002!\�>I�GY��2F�\u001f�ͱ��,	�\u0002	�\u0007�\u0013\u001f8����ݹ�����K��qR�ky˛�|�gZ\u001d>�7\�o��\u001eGf\u0007�\u0012\u000c<�\u0010�B���(����?�0:.���9�"g��\u0006�z&˲,kx/��*�\u0000\u000c\u0000\u0000,"'7' is an invalid end of a number. Expected a delimiter. Path: $.INVALID_JSON | LineNumber: 0 | BytePositionInLine: 20.")
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Bicep_compiler_handles_corrupted_extension_package_gracefully (\u001f�\u0008\u0000\u0000\u0000\u0000\u0000\u0000\u0003���
�0\u000c\u0007��\u0014>AM������{��	��:�`�ػ�\u001e\u0006;(�8\u001d��cCHJ��xg�ma\u000fE�H�\u0014c)�\u0006^����\u0000
�\u0017\u0010�ƀ\u0010Q?�&#����_e�Y?H��mOe�#SB:#�d����\u001b_�O�0����w�⪛��rCC9հ�G�Q���֌O�\u0007P\u00025\u0013\u001b$\u0005���>��d�������A\u0010\u0004A��'(��0\u0000\u000c\u0000\u0000,"The path: index.json was not found in artifact contents")
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Repository_not_found_in_registry (ArtifactRegistryAddress { RegistryAddress = mcr.microsoft.com, RepositoryPath = unknown/path/az, ExtensionVersion = 0.0.0-placeholder },Azure.RequestFailedException: The artifact does not exist in the registry.
   at Bicep.Core.Registry.AzureContainerRegistryManager.DownloadManifestAndLayersAsync(IOciArtifactReference artifactReference, ContainerRegistryContentClient client) in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/AzureContainerRegistryManager.cs:line 138
   at Bicep.Core.Registry.AzureContainerRegistryManager.DownloadManifestAndLayersAsync(IOciArtifactReference artifactReference, ContainerRegistryContentClient client) in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/AzureContainerRegistryManager.cs:line 138,[(BCP192, Error, Unable to restore the artifact with reference "br:mcr.microsoft.com/unknown/path/az:0.0.0-placeholder": The artifact does not exist in the registry.)])
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Repository_not_found_in_registry (ArtifactRegistryAddress { RegistryAddress = mcr.microsoft.com, RepositoryPath = unknown/path/az, ExtensionVersion = 0.0.0-placeholder },Azure.RequestFailedException: The artifact does not exist in the registry.
   at Bicep.Core.Registry.AzureContainerRegistryManager.DownloadManifestAndLayersAsync(IOciArtifactReference artifactReference, ContainerRegistryContentClient client) in D:\a\bicep\bicep\src\Bicep.Core\Registry\AzureContainerRegistryManager.cs:line 138
   at Bicep.Core.Registry.AzureContainerRegistryManager.DownloadManifestAndLayersAsync(IOciArtifactReference artifactReference, ContainerRegistryContentClient client) in D:\a\bicep\bicep\src\Bicep.Core\Registry\AzureContainerRegistryManager.cs:line 138,[(BCP192, Error, Unable to restore the artifact with reference "br:mcr.microsoft.com/unknown/path/az:0.0.0-placeholder": The artifact does not exist in the registry.)])
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Repository_not_found_in_registry (ArtifactRegistryAddress { RegistryAddress = unknown.registry.azurecr.io, RepositoryPath = bicep/extensions/az, ExtensionVersion = 0.0.0-placeholder },System.AggregateException: Retry failed after 4 tries. Retry settings can be adjusted in ClientOptions.Retry or by configuring a custom retry policy in ClientOptions.RetryPolicy. (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443))
   at Bicep.Core.Registry.AzureContainerRegistryManager.DownloadManifestAndLayersAsync(IOciArtifactReference artifactReference, ContainerRegistryContentClient client) in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/AzureContainerRegistryManager.cs:line 138
   at Bicep.Core.Registry.AzureContainerRegistryManager.<>c__DisplayClass4_0.<<PullArtifactAsync>g__DownloadManifestInternalAsync|0>d.MoveNext() in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/AzureContainerRegistryManager.cs:line 44
--- End of stack trace from previous location ---
   at Bicep.Core.Registry.AzureContainerRegistryManager.PullArtifactAsync(RootConfiguration configuration, IOciArtifactReference artifactReference) in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/AzureContainerRegistryManager.cs:line 51
   at Bicep.Core.Registry.AzureContainerRegistryManager.DownloadManifestAndLayersAsync(IOciArtifactReference artifactReference, ContainerRegistryContentClient client) in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/AzureContainerRegistryManager.cs:line 138
   at Bicep.Core.Registry.AzureContainerRegistryManager.<>c__DisplayClass4_0.<<PullArtifactAsync>g__DownloadManifestInternalAsync|0>d.MoveNext() in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/AzureContainerRegistryManager.cs:line 44
--- End of stack trace from previous location ---
   at Bicep.Core.Registry.AzureContainerRegistryManager.PullArtifactAsync(RootConfiguration configuration, IOciArtifactReference artifactReference) in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/AzureContainerRegistryManager.cs:line 63
   at Bicep.Core.Registry.OciArtifactRegistry.TryRestoreArtifactAsync(RootConfiguration configuration, OciArtifactReference reference) in /home/runner/work/bicep/bicep/src/Bicep.Core/Registry/OciArtifactRegistry.cs:line 495,[(BCP192, Error, Unable to restore the artifact with reference "br:unknown.registry.azurecr.io/bicep/extensions/az:0.0.0-placeholder": Retry failed after 4 tries. Retry settings can be adjusted in ClientOptions.Retry or by configuring a custom retry policy in ClientOptions.RetryPolicy. (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)))])
Bicep.Core.IntegrationTests.AzTypesViaRegistryTests ‑ Repository_not_found_in_registry (ArtifactRegistryAddress { RegistryAddress = unknown.registry.azurecr.io, RepositoryPath = bicep/extensions/az, ExtensionVersion = 0.0.0-placeholder },System.AggregateException: Retry failed after 4 tries. Retry settings can be adjusted in ClientOptions.Retry or by configuring a custom retry policy in ClientOptions.RetryPolicy. (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443))
   at Bicep.Core.Registry.AzureContainerRegistryManager.DownloadManifestAndLayersAsync(IOciArtifactReference artifactReference, ContainerRegistryContentClient client) in D:\a\bicep\bicep\src\Bicep.Core\Registry\AzureContainerRegistryManager.cs:line 138
   at Bicep.Core.Registry.AzureContainerRegistryManager.<>c__DisplayClass4_0.<<PullArtifactAsync>g__DownloadManifestInternalAsync|0>d.MoveNext() in D:\a\bicep\bicep\src\Bicep.Core\Registry\AzureContainerRegistryManager.cs:line 44
--- End of stack trace from previous location ---
   at Bicep.Core.Registry.AzureContainerRegistryManager.PullArtifactAsync(RootConfiguration configuration, IOciArtifactReference artifactReference) in D:\a\bicep\bicep\src\Bicep.Core\Registry\AzureContainerRegistryManager.cs:line 51
   at Bicep.Core.Registry.AzureContainerRegistryManager.DownloadManifestAndLayersAsync(IOciArtifactReference artifactReference, ContainerRegistryContentClient client) in D:\a\bicep\bicep\src\Bicep.Core\Registry\AzureContainerRegistryManager.cs:line 138
   at Bicep.Core.Registry.AzureContainerRegistryManager.<>c__DisplayClass4_0.<<PullArtifactAsync>g__DownloadManifestInternalAsync|0>d.MoveNext() in D:\a\bicep\bicep\src\Bicep.Core\Registry\AzureContainerRegistryManager.cs:line 44
--- End of stack trace from previous location ---
   at Bicep.Core.Registry.AzureContainerRegistryManager.PullArtifactAsync(RootConfiguration configuration, IOciArtifactReference artifactReference) in D:\a\bicep\bicep\src\Bicep.Core\Registry\AzureContainerRegistryManager.cs:line 63
   at Bicep.Core.Registry.OciArtifactRegistry.TryRestoreArtifactAsync(RootConfiguration configuration, OciArtifactReference reference) in D:\a\bicep\bicep\src\Bicep.Core\Registry\OciArtifactRegistry.cs:line 495,[(BCP192, Error, Unable to restore the artifact with reference "br:unknown.registry.azurecr.io/bicep/extensions/az:0.0.0-placeholder": Retry failed after 4 tries. Retry settings can be adjusted in ClientOptions.Retry or by configuring a custom retry policy in ClientOptions.RetryPolicy. (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)) (No such host is known. (unknown.registry.azurecr.io:443)))])
…

♻️ This comment has been updated with latest results.

# Conflicts:
#	src/Bicep.Core.IntegrationTests/ScenarioTests.cs
#	src/Bicep.Core.Samples/Files/baselines/Resources_CRLF/main.json
#	src/Bicep.Core.Samples/Files/baselines/Resources_CRLF/main.symbolicnames.json
@jeskew jeskew requested a review from Copilot December 24, 2024 19:19

Choose a reason for hiding this comment

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

Copilot reviewed 18 out of 34 changed files in this pull request and generated no comments.

Files not reviewed (16)
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.diagnostics.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.formatted.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.ir.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.json: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.sourcemap.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.symbolicnames.json: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.symbols.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.syntax.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Dependencies_LF/main.tokens.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/InvalidModules_LF/main.diagnostics.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/InvalidResources_CRLF/main.diagnostics.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Resources_CRLF/main.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Resources_CRLF/main.diagnostics.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Resources_CRLF/main.formatted.bicep: Language not supported
  • src/Bicep.Core.Samples/Files/baselines/Resources_CRLF/main.ir.bicep: Language not supported
# Conflicts:
#	src/Bicep.Core.IntegrationTests/ScenarioTests.cs
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Two mutually-exclusive conditional resources with the same type and name will throw name validation error
1 participant