Esta regra sinaliza os elementos Context <Environment> localizados no arquivo META-INF/context.xml que devem ser transformados nos elementos <env-entry> no arquivo WEB-INF/web.xml.
O Apache Tomcat permite que os elementos Context <Environment> sejam definidos nestes locais:
Como a ferramenta de migração pode não ter acesso ao diretório de configuração do Tomcat, ela sinaliza somente o Context <Environment> no arquivo META-INF/context.xml. As informações Context <Environment> definidas nos outros locais podem ser copiadas para o arquivo META-INF/context.xml para que sejam processadas pela ferramenta.
Se existir um WEB-INF/web.xml no projeto da web:
Os elementos Context <Environment> serão sinalizados sob qualquer uma das condições a seguir:
Há uma correção rápida para essa regra disponível no scanner de origem. A correção rápida incluirá um novo elemento <env-entry> no arquivo web.xml que representa o elemento Context <Environment> se ele ainda não existir no arquivo web.xml. Se a entrada existir, ela será atualizada.
Se WEB-INF/web.xml não existir:
Todos os elementos Context <Environment> será sinalizados.
A correção rápida criará um arquivo WEB-INF/web.xml que inclui os elementos <env-entry> apropriados, se o projeto da web estiver em Java EE 5 ou superior. A correção rápida relatará um erro se o projeto da web estiver em J2EE 1.4 ou inferior.
Por exemplo, considere um arquivo META-INF/context.xml com o conteúdo a seguir:|
<Environment description="Trigger because it does not exist" name="newEntry" override="false" type="java.lang.String" value="abc123"/> <Environment description="Trigger because of different value" name="contextEnvString_1" override="false" type="java.lang.String" value="new Value"/> <Environment description="Trigger because of different type" name="contextEnvString_2" override="false" type="java.lang.Integer" value="123"/> <Environment description="will not Trigger because of override set to true." name="contextEnvString_3" override="true" type="java.lang.Integer" value="123"/> |
Com o arquivo web.xml a seguir no aplicativo:
|
<env-entry> <description>Trigger because of different value</description> <env-entry-name>contextEnvString_1</env-entry-name> <env-entry-type>java.lang.String</env-entry-type> <env-entry-value>oldValue</env-entry-value> </env-entry> <env-entry> <description>Trigger because of different type</description> <env-entry-name>contextEnvString_2</env-entry-name> <env-entry-type>java.lang.String</env-entry-type> <env-entry-value>123</env-entry-value> </env-entry> <env-entry> <description>will not Trigger because of override set to true.</description> <env-entry-name>contextEnvString_3</env-entry-name> <env-entry-type>java.lang.Integer</env-entry-type> <env-entry-value>123456789</env-entry-value> </env-entry> |
Depois que a correção rápida for aplicada, o web.xml será atualizado para conter:
|
<env-entry> <description>Trigger because of different value</description> <env-entry-name>contextEnvString_1</env-entry-name> <env-entry-type>java.lang.String</env-entry-type> <env-entry-value>new Value</env-entry-value> </env-entry> <env-entry> <description>Trigger because of different type</description> <env-entry-name>contextEnvString_2</env-entry-name> <env-entry-type>java.lang.Integer</env-entry-type> <env-entry-value>123</env-entry-value> </env-entry> <env-entry> <description>will not Trigger because of override set to true.</description> <env-entry-name>contextEnvString_3</env-entry-name> <env-entry-type>java.lang.Integer</env-entry-type> <env-entry-value>123456789</env-entry-value> </env-entry> <env-entry> <description>Trigger because it does not exist</description> <env-entry-name>newEntry</env-entry-name> <env-entry-type>java.lang.String</env-entry-type> <env-entry-value>abc123</env-entry-value> </env-entry> |