이 콘텐츠는 선택한 언어로 제공되지 않습니다.
Chapter 2. Getting started with rules
You can get started creating custom MTR rules by creating a rule or by reviewing the quickstarts.
2.1. Creating your first XML rule
This section guides you through the process of creating and testing your first MTR XML-based rule. This assumes that you have already installed MTR. See Installing and running the CLI in the CLI Guide for installation instructions.
				In this example, you will write a rule to discover instances where an application defines a jboss-web.xml file containing a <class-loading> element and provide a link to the documentation that describes how to migrate the code.
			
Creating the directory structure for the rule
Create a directory structure to contain your first rule and the data file to use for testing.
mkdir -p /home/<USER_NAME>/migration-rules/rules mkdir -p /home/<USER_NAME>/migration-rules/data
$ mkdir -p /home/<USER_NAME>/migration-rules/rules
$ mkdir -p /home/<USER_NAME>/migration-rules/dataThis directory structure will also be used to hold the generated MTR reports.
Creating data to test the rule
- 
						Create a jboss-web.xmlfile in the/home/<USER_NAME>/migration-rules/data/subdirectory.
- Copy in the following content. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Creating the rule 
MTR XML-based rules use the following rule pattern:
when(condition) perform(action) otherwise(action)
when(condition)
  perform(action)
otherwise(action)Procedure
- In the - /home/<USER_NAME>/migration-rules/rules/directory, create a file named- JBoss5-web-class-loading.windup.xmlthat contains the following content:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- The XML file name must include the - .windup.xmlextension. Otherwise, MTR does not evaluate the new rule.
- Add a unique identifier for the ruleset and rule: - 
								Replace <UNIQUE_RULESET_ID>with an appropriate ruleset ID, for example,JBoss5-web-class-loading.
- 
								Replace <UNIQUE_RULE_ID>with an appropriate rule ID, for example,JBoss5-web-class-loading_001.
 
- 
								Replace 
- Add the following ruleset add-on dependencies: - <dependencies> <addon id="org.jboss.windup.rules,windup-rules-javaee,3.0.0.Final"/> <addon id="org.jboss.windup.rules,windup-rules-java,3.0.0.Final"/> </dependencies> - <dependencies> <addon id="org.jboss.windup.rules,windup-rules-javaee,3.0.0.Final"/> <addon id="org.jboss.windup.rules,windup-rules-java,3.0.0.Final"/> </dependencies>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add the source and target technologies: - 
								Replace <SOURCE_ID>witheap.
- 
								Replace <TARGET_ID>witheap.
 
- 
								Replace 
- Set the source and target technology versions. - 
								Replace <SOURCE_VERSION_RANGE>with(4,5).
- 
								Replace <TARGET_VERSION_RANGE>with(6,).
 - See the Apache Maven version range specification for more information. 
- 
								Replace 
- Complete the - whencondition. Because this rule tests for a match in an XML file,- xmlfileis used to evaluate the files.- To match on the - class-loadingelement that is a child of- jboss-web, use the xpath expression- jboss-web/class-loading.- <when> <xmlfile matches="jboss-web/class-loading" /> </when>- <when> <xmlfile matches="jboss-web/class-loading" /> </when>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Complete the - performaction for this rule.- 
								Add a classification with a descriptive title and a level of effort of 1.
- Provide a hint with an informative message and a link to documentation that describes the migration details. - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- 
								Add a classification with a descriptive title and a level of effort of 
The rule is now complete and should look like the following example.
Installing the rule
An MTR rule is installed by placing the rule into the appropriate directory.
				Copy the JBoss5-web-class-loading.windup.xml file to the <MTR_HOME>/rules/ directory.
			
cp /home/<USER_NAME>/migration-rules/rules/JBoss5-web-class-loading.windup.xml <MTR_HOME>/rules/
$ cp /home/<USER_NAME>/migration-rules/rules/JBoss5-web-class-loading.windup.xml <MTR_HOME>/rules/Testing the rule
Open a terminal and run the following command, passing the test file as an input argument and a directory for the output report.
<MTR_HOME>/bin/windup-cli --sourceMode --input /home/<USER_NAME>/migration-rules/data --output /home/<USER_NAME>/migration-rules/reports --target eap:6
$ <MTR_HOME>/bin/windup-cli --sourceMode --input /home/<USER_NAME>/migration-rules/data --output /home/<USER_NAME>/migration-rules/reports --target eap:6You should see the following result.
Report created: /home/<USER_NAME>/migration-rules/reports/index.html
              Access it at this URL: file:///home/<USER_NAME>/migration-rules/reports/index.html
Report created: /home/<USER_NAME>/migration-rules/reports/index.html
              Access it at this URL: file:///home/<USER_NAME>/migration-rules/reports/index.htmlReviewing the reports
Review the report to be sure that it provides the expected results. For a more detailed walkthrough of MTR reports, see the Reviewing the reports section of the MTR CLI Guide.
- 
						Open /home/<USER_NAME>/migration-rules/reports/index.htmlin a web browser.
- Verify that the rule ran successfully. - From the main landing page, click the Rule providers execution overview link to open the Rule Providers Execution Overview.
- Find the - JBoss5-web-class-loading_001rule and verify that its Status? is- Condition metand its Result? is- success.- Figure 2.1. Test rule execution 
 
- Verify that the rule matches the test data: - 
								From the main landing page, click the name of the application or input folder, which is datain this example.
- Click the Application Details report link.
- Click the jboss-web.xml link to view the Source Report. - You can see that the - <class-loading>line is highlighted, and the hint from the custom rule is shown inline.- Figure 2.2. Rule match - The top of the file lists the classifications for matching rules. You can use the link icon to view the details for that rule. Notice that in this example, the - jboss-web.xmlfile matched on another rule (- JBoss web application descriptor (jboss-web.xml)) that produced- 1story point. This story point, combined with the- 1story point from our custom rule, brings the total story points for this file to- 2.
 
- 
								From the main landing page, click the name of the application or input folder, which is 
2.2. Reviewing the Migration Toolkit for Runtimes quickstarts
The Migration Toolkit for Runtimes quickstarts provide working examples of how to create custom Java-based rule add-ons and XML rules. You can use them as a starting point for creating your own custom rules.
				Each quickstart has a README.adoc file that contains instructions for that quickstart.
			
				You can download a .zip file of the latest version of the quickstarts. If you prefer to work with the source code, you can fork and clone the windup-quickstarts project repository.
			
Downloading the latest quickstart
You can download the latest release of a quickstart.
Procedure
- Launch a browser and navigate to https://github.com/windup/windup-quickstarts/releases.
- 
						Click the latest release to download the .zipfile to your local file system.
- Extract the archive files to a local directory. - You can review the quickstart - README.adocfile.
Forking and cloning the quickstart GitHub project
You can fork and clone the Quickstart Github project on your local machine.
Prerequisites
- 
						You must have gitclient installed.
Procedure
- 
						Click Fork on the Migration Toolkit for Runtimes quickstart GitHub page to create the project in your own Git. The forked GitHub repository URL should look like this: https://github.com/<YOUR_USER_NAME>/windup-quickstarts.git.
- Clone the Migration Toolkit for Runtimes quickstart repository to your local file system: - git clone https://github.com/<YOUR_USER_NAME>/windup-quickstarts.git - $ git clone https://github.com/<YOUR_USER_NAME>/windup-quickstarts.git- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This creates a - windup-quickstartsdirectory on your local file system.
- Navigate to the newly created directory: - cd windup-quickstarts/ - $ cd windup-quickstarts/- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To retrieve the latest code updates, add the remote - upstreamrepository so that you can fetch changes to the original forked repository:- git remote add upstream https://github.com/windup/windup-quickstarts.git - $ git remote add upstream https://github.com/windup/windup-quickstarts.git- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Download the latest files from the - upstreamrepository:- git fetch upstream - $ git fetch upstream- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
    