Casos de teste para createUiDefinition.json
Este artigo descreve os testes que são executados com o kit de ferramentas de teste de modelo para arquivos createUiDefinition.json. Os exemplos incluem os nomes de teste e exemplos de código que passam ou falham nos testes.
O kit de ferramentas inclui casos de teste para modelos do Azure Resource Manager (modelos ARM) e os principais arquivos de modelo chamados azuredeploy.json ou maintemplate.json. Quando o diretório contém um arquivo createUiDefinition.json , testes específicos são executados para controles de interface do usuário. Para obter mais informações sobre como executar testes ou como executar um teste específico, consulte Parâmetros de teste.
O arquivo createUiDefinition.json cria controles personalizados de interface do usuário (UI) usando elementos e funções.
Verificar parâmetro de modelo permite valores
Nome do teste: Os valores permitidos devem realmente ser permitidos
Este teste verifica se os valores para cada controle em createUiDefinition.json são permitidos nos parâmetros do modelo principal. Os parâmetros são mapeados por nome entre o modelo principal e o arquivo createUiDefinition.json .
O parâmetro do modelo principal deve aceitar os valores do controle allowedValues
. O teste também verifica se o controle é referenciado na seção createUiDefinition.jsonoutputs
.
Este teste verifica o modelo principal e createUiDefinition.json arquivo. Um exemplo do arquivo createUiDefinition.json é mostrado após os exemplos de modelo principal.
O exemplo a seguir falha porque o nome combo
do parâmetro do modelo principal não corresponde ao nome comboBox
do parâmetro do controle.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"combo": {
"type": "string",
"defaultValue": "two"
}
},
"resources": [],
"outputs": {
"comboBoxOutput": {
"type": "string",
"value": "[parameters('combo')]"
}
}
}
O exemplo a seguir falha porque o tipo int
de parâmetro do modelo principal não aceita o valor do string
controle. E se o parâmetro de um modelo principal define um defaultValue
, ele deve ser válido value
no controle allowedValues
.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"comboBox": {
"type": "int",
"defaultValue": 4
}
},
"resources": [],
"outputs": {
"comboBoxOutput": {
"type": "string",
"value": "[parameters('combo')]"
}
}
}
O exemplo a seguir passa porque o nome do parâmetro do modelo principal corresponde ao nome do parâmetro do controle. E o tipo de parâmetro do modelo é um string
com a defaultValue
especificado no .allowedValues
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"comboBox": {
"type": "string",
"defaultValue": "two"
}
},
"resources": [],
"outputs": {
"comboBoxOutput": {
"type": "string",
"value": "[parameters('comboBox')]"
}
}
}
O arquivo createUiDefinition.json para este exemplo:
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [],
"steps": [
{
"name": "demoComboBox",
"label": "demoComboBoxLabel",
"elements": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"defaultValue": "Value two",
"toolTip": "This is a tool tip",
"constraints": {
"allowedValues": [
{
"label": "Value one",
"description": "The value to select for option 1.",
"value": "one"
},
{
"label": "Value two",
"description": "The value to select for option 2.",
"value": "two"
}
],
"required": true
},
"visible": true
}
]
}
],
"outputs": {
"comboBox": "[steps('demoComboBox').comboBox]"
}
}
}
Os controles de saída devem existir
Nome do teste: Os controles nas saídas devem existir
Os controles usados na outputs
seção devem existir em um elemento em outro lugar no createUiDefinition.json. O nome mencionado em outputs
deve corresponder a um nome usado em basics[]
ou steps[]
.
O exemplo a seguir falha.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "nameDoesNotMatchOutput",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"comboBox": "[basics('comboBox')]"
}
}
}
O exemplo a seguir passa.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"comboBox": "[basics('comboBox')]"
}
}
}
As propriedades devem incluir valores
Nome do teste: CreateUIDefinition não deve ter espaços em branco
As propriedades devem incluir valores. As propriedades necessárias devem usar valores válidos. As propriedades opcionais que estão em branco devem ser removidas. O teste permite em branco "basics": []
, "steps": []
, ou defaultValue
.
O exemplo a seguir falha porque label
, placeholder
, e toolTip
estão em branco.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "",
"placeholder": "",
"defaultValue": "",
"toolTip": ""
}
],
"steps": [],
"outputs": {
"comboBox": "[basics('comboBox')]"
}
}
}
O exemplo a seguir passa porque label
e toolTip
tem valores, e placeholder
foi removido.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"defaultValue": "",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"comboBox": "[basics('comboBox')]"
}
}
}
Usar esquema e versão válidos
Nome do teste: CreateUIDefinition deve ter esquema
O arquivo createUiDefinition.json deve incluir uma $schema
propriedade e usar um arquivo válido $schema
e version
. Os números de versão em $schema
e version
devem corresponder.
O exemplo a seguir falha.
{
"$schema": "https://schema.management.azure.com/schemas/0.9.9-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.9.9-preview"
}
O exemplo a seguir passa porque usa o mais recente $schema
e version
.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview"
}
Não oculte a confirmação de credenciais
Nome do teste: A confirmação da credencial não deve ser ocultada
Este teste verifica se as credenciais estão confirmadas para Microsoft.Common.PasswordBox ou Microsoft.Compute.CredentialsCombo. A hideConfirmation
propriedade deve ser definida como false
para que a confirmação seja visível.
O exemplo a seguir falha porque hideConfirmation
é true
.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "credentials",
"type": "Microsoft.Compute.CredentialsCombo",
"label": {
"password": "Password",
"confirmPassword": "Confirm password"
},
"toolTip": {
"password": "Type your credentials"
},
"constraints": {
"required": true,
"customPasswordRegex": "^(?=.*[A-Za-z])(?=.*\\d)[A-Za-z\\d]{12,}$",
"customValidationMessage": "The password must be alphanumeric, contain at least 12 characters, and have at least 1 letter and 1 number."
},
"options": {
"hideConfirmation": true
},
"osPlatform": "Windows",
"visible": true
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"credentials": "[basics('credentials')]"
}
}
}
O exemplo a seguir passa porque hideConfirmation
é false
.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "credentials",
"type": "Microsoft.Compute.CredentialsCombo",
"label": {
"password": "Password",
"confirmPassword": "Confirm password"
},
"toolTip": {
"password": "Type your credentials"
},
"constraints": {
"required": true,
"customPasswordRegex": "^(?=.*[A-Za-z])(?=.*\\d)[A-Za-z\\d]{12,}$",
"customValidationMessage": "The password must be alphanumeric, contain at least 12 characters, and have at least 1 letter and 1 number."
},
"options": {
"hideConfirmation": false
},
"osPlatform": "Windows",
"visible": true
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"credentials": "[basics('credentials')]"
}
}
}
Use o manipulador correto
Nome do teste: O manipulador deve estar correto
Use Microsoft.Azure.CreateUIDef
ou Microsoft.Compute.MultiVm
no arquivo createUiDefinition.json .
O exemplo a seguir falha.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.",
"version": "0.1.2-preview"
}
O exemplo a seguir passa.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview"
}
Não oculte os recursos existentes
Nome do teste: HideExisting deve ser manipulado corretamente
Se hideExisting
estiver definido como false
ou omitido, outputs
deve conter resourceGroup
e newOrExisting
. O padrão para hideExisting
é false
.
Exemplos de tipos de controle que incluem hideExisting
são Microsoft.Storage.StorageAccountSelector, Microsoft.Network.PublicIpAddressCombo ou Microsoft.Network.VirtualNetworkCombo.
O exemplo a seguir falha.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "storage",
"type": "Microsoft.Storage.StorageAccountSelector",
"label": "Storage account",
"toolTip": "This is a demo storage account",
"defaultValue": {
"name": "storageaccount01",
"type": "Premium_LRS"
},
"options": {
"hideExisting": false
},
"visible": true
}
],
"steps": [],
"outputs": {
"location": "[location()]"
}
}
}
O exemplo a seguir passa.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "storage",
"type": "Microsoft.Storage.StorageAccountSelector",
"label": "Storage account",
"toolTip": "This is a demo storage account",
"defaultValue": {
"name": "storageaccount01",
"type": "Premium_LRS"
},
"options": {
"hideExisting": false
},
"visible": false
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"resourceGroup": "[basics('storage').resourceGroup]",
"newOrExisting": "[basics('storage').newOrExisting]"
}
}
}
Usar localização em saídas
Nome do teste: O local deve estar nas saídas
A outputs
seção deve conter um local usando a função de localização .
O exemplo a seguir falha porque outputs
não inclui um local.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"comboBox": "[basics('comboBox')]"
}
}
}
O exemplo a seguir passa.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"comboBox": "[basics('comboBox')]",
"location": "[location()]"
}
}
}
Incluir saídas de controle nos parâmetros do modelo
Nome do teste: As saídas devem estar presentes nos parâmetros do modelo
O teste verifica se createUiDefinition.json inclui uma outputs
seção. O teste também verifica se eles outputs
estão definidos na seção do parameters
modelo principal. Os nomes devem corresponder porque os parâmetros são mapeados por nome entre o createUiDefinition.json e o modelo principal.
Este teste verifica o modelo principal e createUiDefinition.json arquivo. Um exemplo do arquivo createUiDefinition.json é mostrado após os exemplos de modelo principal.
O exemplo a seguir falha porque o modelo principal não inclui o comboBox
parâmetro da seção do arquivo outputs
createUiDefinition.json.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"location": {
"type": "string",
"defaultValue": "[resourceGroup().location]"
}
},
"resources": [],
"outputs": {
"location": {
"type": "string",
"value": "[parameters('location')]"
}
}
}
O exemplo a seguir passa porque o modelo principal inclui o comboBox
parâmetro.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"comboBox": {
"type": "string",
"defaultValue": "two"
},
"location": {
"type": "string",
"defaultValue": "[resourceGroup().location]"
}
},
"resources": [],
"outputs": {
"comboBox": {
"type": "string",
"value": "[parameters('comboBox')]"
},
"location": {
"type": "string",
"value": "[parameters('location')]"
}
}
}
O arquivo createUiDefinition.json para este exemplo:
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"comboBox": "[basics('comboBox')]",
"location": "[location()]"
}
}
}
Parâmetros sem padrão devem existir nas saídas
Nome do teste: parâmetros sem padrão devem existir em CreateUIDefinition
Os parâmetros no modelo principal sem um valor padrão devem existir na seção do arquivo outputs
createUiDefinition.json.
Este teste verifica o modelo principal e createUiDefinition.json arquivo. Um exemplo do arquivo azuredeploy.json é mostrado após os exemplos do controle.
O exemplo a seguir falha porque o arquivo outputs
createUiDefinition.json não inclui o parâmetro comboBox
do modelo principal.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"location": "[location()]"
}
}
}
O exemplo a seguir passa porque createUiDefinition.json inclui o comboBox
in outputs
.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"comboBox": "[basics('comboBox')]",
"location": "[location()]"
}
}
}
O arquivo azuredeploy.json para este exemplo. O comboBox
parâmetro não tem um valor padrão.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"comboBox": {
"type": "string"
},
"location": {
"type": "string"
}
},
"resources": [],
"outputs": {
"comboBox": {
"type": "string",
"value": "[parameters('comboBox')]"
},
"location": {
"type": "string",
"value": "[parameters('location')]"
}
}
}
Use parâmetro seguro com caixa de senha
Nome do teste: caixas de texto de senha devem ser usadas para parâmetros de senha
Este teste verifica se um elemento Microsoft.Common.PasswordBox está definido no modelo parameters
principal e no createUiDefinition.json outputs
. O tipo de parâmetro do modelo principal para uma caixa de senha deve ser secureString
ou secureObject
.
Este teste verifica o modelo principal e createUiDefinition.json arquivo. Um exemplo do arquivo createUiDefinition.json é mostrado após os exemplos de modelo principal.
O exemplo a seguir falha porque o parâmetro do passwordBox
modelo principal é um string
arquivo .
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"passwordBox": {
"type": "string"
},
"location": {
"type": "string"
}
},
"resources": [],
"outputs": {
"location": {
"type": "string",
"value": "[parameters('location')]"
}
}
}
O exemplo a seguir passa porque o parâmetro do passwordBox
modelo principal é um secureString
arquivo .
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"passwordBox": {
"type": "secureString"
},
"location": {
"type": "string"
}
},
"resources": [],
"outputs": {
"location": {
"type": "string",
"value": "[parameters('location')]"
}
}
}
O arquivo createUiDefinition.json para este exemplo:
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "passwordBox",
"type": "Microsoft.Common.PasswordBox",
"label": {
"password": "Password",
"confirmPassword": "Confirm password"
},
"toolTip": "Type a password"
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"passwordBox": "[basics('passwordBox')]"
}
}
}
A caixa de palavra-passe requer um comprimento mínimo
Nome do teste: PasswordBoxes deve ter comprimento mínimo
O teste verifica se o elemento Microsoft.Common.PasswordBox usa constraints
com um regex
que requer pelo menos 12 caracteres.
O exemplo a seguir falha porque não constraints
há .
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "passwordBox",
"type": "Microsoft.Common.PasswordBox",
"label": {
"password": "Password",
"confirmPassword": "Confirm password"
},
"toolTip": "Type a password"
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"passwordBox": "[basics('passwordBox')]"
}
}
}
O exemplo a seguir passa porque o regex
requer pelo menos 12 caracteres.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "passwordBox",
"type": "Microsoft.Common.PasswordBox",
"label": {
"password": "Password",
"confirmPassword": "Confirm password"
},
"toolTip": "Type a password",
"constraints": {
"required": true,
"regex": "^[a-zA-Z0-9]{12,}$",
"validationMessage": "Password must be at least 12 characters long, contain only numbers and letters"
}
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"passwordBox": "[basics('passwordBox')]"
}
}
}
Caixa de texto deve usar validação
Nome do teste: As caixas de texto estão bem formadas
Use a validação com caixas de texto para verificar constraints
se contém um regex
e message
.
O exemplo a seguir falha.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "textBox",
"type": "Microsoft.Common.TextBox",
"label": "Text box",
"toolTip": "Type 1-30 alphanumeric characters",
"placeholder": "Type your text here",
"visible": true
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"textBox": "[basics('textBox')]"
}
}
}
O exemplo a seguir passa.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "textBox",
"type": "Microsoft.Common.TextBox",
"label": "Text box",
"toolTip": "Type 1-30 alphanumeric characters",
"placeholder": "Type your text here",
"constraints": {
"required": true,
"validations": [
{
"regex": "^[a-z0-9A-Z]{1,30}$",
"message": "Only 1-30 characters alphanumeric characters are allowed."
}
]
},
"visible": true
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"textBox": "[basics('textBox')]"
}
}
}
toolTip deve existir com um valor
Nome do teste: Dicas de ferramentas devem estar presentes
Este teste verifica se a toolTip
propriedade existe e contém um valor.
O exemplo a seguir falha.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": ""
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"comboBox": "[basics('comboBox')]"
}
}
}
O exemplo a seguir passa.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "comboBox",
"type": "Microsoft.Common.DropDown",
"label": "Example drop down",
"toolTip": "This is a tool tip"
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"comboBox": "[basics('comboBox')]"
}
}
}
Não defina um nome de usuário padrão
Nome de teste: Os nomes de usuário não devem ter um padrão
O teste verifica se há um defaultValue
conjunto para Microsoft.Compute.UserNameTextBox.
O exemplo a seguir falha porque um defaultValue
é fornecido.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "userNameBox",
"type": "Microsoft.Compute.UserNameTextBox",
"label": "User name",
"defaultValue": "admin",
"toolTip": "Enter your user name",
"osPlatform": "Windows"
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"userNameBox": "[basics('userNameBox')]"
}
}
}
O exemplo a seguir passa.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "userNameBox",
"type": "Microsoft.Compute.UserNameTextBox",
"label": "User name",
"toolTip": "Enter your user name",
"osPlatform": "Windows"
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"userNameBox": "[basics('userNameBox')]"
}
}
}
Usar mensagem com validações
Nome do teste: As validações devem ter mensagem
Este teste verifica se qualquer validations
createUiDefinition.json incluir um message
arquivo .
O exemplo a seguir falha porque a regex
validação não tem um message
arquivo .
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "textBox",
"type": "Microsoft.Common.TextBox",
"label": "Text box",
"toolTip": "Type 1-30 alphanumeric characters",
"placeholder": "Type your text here",
"constraints": {
"required": true,
"validations": [
{
"regex": "^[a-z0-9A-Z]{1,30}$"
}
]
},
"visible": true
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"textBox": "[basics('textBox')]"
}
}
}
O exemplo a seguir passa.
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "textBox",
"type": "Microsoft.Common.TextBox",
"label": "Text box",
"toolTip": "Type 1-30 alphanumeric characters",
"placeholder": "Type your text here",
"constraints": {
"required": true,
"validations": [
{
"regex": "^[a-z0-9A-Z]{1,30}$",
"message": "Only 1-30 characters alphanumeric characters are allowed."
}
]
},
"visible": true
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"textBox": "[basics('textBox')]"
}
}
}
Os tamanhos das máquinas virtuais devem corresponder
Nome do teste: Os tamanhos da VM devem corresponder ao modelo
Este teste verifica se o Microsoft.Compute.SizeSelector está na seção createUiDefinition.json outputs
e do modelo parameters
principal. Os principais parâmetros de modelo que especificam um deve corresponder a defaultValue
um valor no controle allowedSizes
.
Este teste verifica o modelo principal e createUiDefinition.json arquivo. Um exemplo do arquivo createUiDefinition.json é mostrado após os exemplos de modelo principal.
O exemplo a seguir falha porque o modelo defaultValue
principal não corresponde a um valor em allowedSizes
.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"location": {
"type": "string"
},
"vmSize": {
"type": "string",
"defaultValue": "Standard_D9"
}
},
"resources": [],
"outputs": {
"location": {
"type": "string",
"value": "[parameters('location')]"
},
"vmSize": {
"type": "string",
"value": "[parameters('vmSize')]"
}
}
}
O exemplo a seguir passa porque o modelo defaultValue
principal corresponde a um valor em allowedSizes
.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"location": {
"type": "string"
},
"vmSize": {
"type": "string",
"defaultValue": "Standard_D3"
}
},
"resources": [],
"outputs": {
"location": {
"type": "string",
"value": "[parameters('location')]"
},
"vmSize": {
"type": "string",
"value": "[parameters('vmSize')]"
}
}
}
O arquivo createUiDefinition.json para este exemplo:
{
"$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#",
"handler": "Microsoft.Azure.CreateUIDef",
"version": "0.1.2-preview",
"parameters": {
"basics": [
{
"name": "vmSize",
"type": "Microsoft.Compute.SizeSelector",
"label": "VM Size",
"toolTip": "Select a virtual machine size",
"recommendedSizes": [
"Standard_D1"
],
"constraints": {
"allowedSizes": [
"Standard_D1",
"Standard_D2",
"Standard_D3"
]
},
"osPlatform": "Windows",
"visible": true
}
],
"steps": [],
"outputs": {
"location": "[location()]",
"vmSize": "[basics('vmSize')]"
}
}
}
Próximos passos
- Para criar uma interface de usuário do portal do Azure, consulte CreateUiDefinition.json para a experiência de criação do aplicativo gerenciado do Azure.
- Para usar a Área Restrita Criar Definição de Interface do Usuário, consulte Testar a interface do portal para Aplicativos Gerenciados do Azure.
- Para obter mais informações sobre controles de interface do usuário, consulte Elementos CreateUiDefinition e funções CreateUiDefinition.
- Para saber mais sobre testes de modelo ARM, consulte Casos de teste para modelos ARM.