Merge branch 'pr-1956'

This commit is contained in:
Andreas Dangel
2019-08-10 22:21:22 +02:00
24 changed files with 318 additions and 1 deletions

View File

@ -67,6 +67,9 @@ entries:
- title: Writing XPath rules
url: /pmd_userdocs_extending_writing_xpath_rules.html
output: web, pdf
- title: Rule designer reference
url: /pmd_userdocs_extending_designer_reference.html
output: web, pdf
- title: Defining rule properties
url: /pmd_userdocs_extending_defining_properties.html
output: web, pdf

View File

@ -0,0 +1,22 @@
# Mimics an HTML <details> element
# Courtesy of https://github.com/towbi (https://gist.github.com/towbi/a67fda47e075d2b7fa4764bb42605063)
class DetailsTag < Liquid::Block
def initialize(tag_name, markup, tokens)
super
@caption = markup
end
def render(context)
site = context.registers[:site]
converter = site.find_converter_instance(::Jekyll::Converters::Markdown)
# below Jekyll 3.x use this:
# converter = site.getConverterImpl(::Jekyll::Converters::Markdown)
caption = converter.convert(@caption).gsub(/<\/?p[^>]*>/, '').chomp
body = converter.convert(super(context))
"<details><summary>#{caption}</summary>#{body}</details>"
end
end
Liquid::Template.register_tag('details', DetailsTag)

View File

@ -19,4 +19,36 @@
top: 50px; /* height of the nav bar */
bottom: 0px;
width: 100%;
}
}
details {
border-radius: 3px;
background: #EEE;
margin-left: 10px;
}
details p {
padding: 5px 10px 5px;
background: white;
}
details summary {
font-size: 11pt;
vertical-align: top;
background: #d2d2d2;
color: black;
border-radius: 3px;
padding: 5px 10px;
outline: none;
cursor: pointer;
display: list-item;
}
details summary::after {
content: "...";
}
details[open] summary {
background-color: #347DBE;
color: white;
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 28 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 216 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 77 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 181 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 283 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 27 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 23 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 179 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 275 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 246 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 85 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 161 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 71 KiB

View File

@ -0,0 +1,254 @@
---
title: The rule designer
short_title: Rule designer
tags: [extending, userdocs]
summary: "Learn about the usage and features of the rule designer."
last_updated: August 2019 (6.18.0)
permalink: pmd_userdocs_extending_designer_reference.html
author: Clément Fournier <clement.fournier76@gmail.com>
---
## Installing, running, updating
The designer is part of PMD's binary distributions. To **install a distribution**, see the [documentation page about installing PMD](pmd_userdocs_installation.html).
The app needs JRE 1.8 or above to run. Be aware that on JRE 11+, the JavaFX distribution should be installed separately. Visit the [JavaFX download page](https://gluonhq.com/products/javafx/) to download a distribution, extract it, and set the JAVAFX_HOME environment variable.
If the bin directory of your PMD distribution is on your shell's path, then you can **launch the app** with
run.sh designer on Linux/ OSX
designer.bat on Windows
{% include note.html content="pmd-ui.jar is not a runnable jar, because it doesn't include any PMD language module, or PMD Core. " %}
This is to allow easy updating, and let you choose the dependencies you're interested in.
The available language modules are those on the classpath of the app's JVM. That's why it's recommended to use the standard PMD startup scripts, which setup the classpath with the available PMD libraries.
### Updating
The latest version of the designer currently **works with PMD 6.12.0 and above**. You can simply replace pmd-ui-6.X.Y.jar with the [latest build](https://github.com/pmd/pmd-designer/releases) in the installation folder of your PMD distribution, and run it normally. Note that updating may cause some persisted state to get lost, for example the code snippet.
# Usage reference
The rule designer is both a tool to inspect the tree on which PMD rules run on, and to write XPath rules in an integrated manner. This page describes the features that enable this.
## AST inspection
![Designer top UI](images/designer/designer-top.png)
You can enter source code in the middle zone.
* Make sure to select the correct language and version for your source code:
* Language is set app-wide with the blue button in the menu-bar
* If the language has several language versions, you can select a specific one with the choicebox just above the code area
* If the source is valid using this setting, the tree to the right will update to display the AST of the code
* When selecting a node, the left panel updates with information about a node
### Selecting nodes
There are several ways to focus a node for inspection:
* **From the tree view:** just click on an item
* Since 6.16.0, the tree view is also searchable: press CTRL+F when it's focused, or click on the `Search` button and enter a search query. You can cycle through results with `CTRL+TAB` or `CTRL+F3`, and cycle back with `CTRL+SHIFT+TAB` or `CTRL+SHIFT+F3`
* **From the crumb bar:** the crumb bar below the code area shows the ancestors of the currently selected node, and is empty if you have no selection:
{% details Ancestor crumb bar demo %}
![Ancestor crumb bar demo](images/designer/parents-bar.gif)
{% enddetails %}
* **From the source code:** maintain **CTRL** for a second until the code area becomes mostly blue. Then, each node you hover over on the code area will be selected automatically. Example:
{% details CTRL-hover selection demo %}
![CTRL-hover selection demo](images/designer/hover-selection.gif)
{% enddetails %}
### Node inspection
The left panel displays the following information:
* **XPath attributes:** this basically are all the attributes available in XPath queries. Those attributes are wrappers around a Java getter, so you can obtain documentation on the relevant Javadoc (that's not yet integrated into the designer)
* **Metrics:** for nodes that support it, the values of metrics are displayed in this panel
* **Scopes:** This is java specific and displays some representation of the symbol table. You mostly don't need it. If you select eg a variable id, its usages are already highlighted automatically without opening the panel:
![Usages highlight example](images/designer/usages.gif)
## XPath rule design
The bottom part of the UI is dedicated to designing XPath rules:
![Bottom UI](images/designer/bottom-ui.png)
The center is an XPath expression. As you type it, the matched nodes are updated on the right, and highlighted on the code area. Autocompletion is available on some languages.
Note: you can keep several rules in the editor (there's a tab for each of them).
### Rule properties
Above the XPath expression area, the **"Properties"** button allows you to [define new properties](pmd_userdocs_extending_defining_properties.html#for-xpath-rules) for your prototype rule. You can also edit the existing properties.
When you click on it, a small popup appears:
![Property definition popup](images/designer/property-defs.png)
The popup contains in the center a list of currently defined properties, displaying their name and expected type.
* **Adding**: the "Add property" button adds a row to the table
* **Deleting**: each item has a "Trash" button to delete the property
* **Editing**: each property can be further edited by clicking on the "Ellipsis" button on the right
#### Editing properties
The edition menu of a property looks like the following:
![Property edition popup](images/designer/property-edit.png)
* You can edit the name, description, expected type, and default value of the property
* All this information is exported with the rule definition (see [Exporting to an XML rule](#exporting-to-an-xml-rule))
* The default value is used unless you're editing a test case, and you set a custom value for the test case. TODO link
### Exporting to an XML rule
The little **export icon** next to the gear icon opens a menu to export your rule. This menu lets you fill-in the metadata necessary for an XPath rule to be included in a ruleset.
{% details Rule export demo %}
![Rule export demo](images/designer/export-example.gif)
{% enddetails %}
## Testing a rule
PMD has its own XML format to describe rule tests and execute them using our test framework. The designer includes a test editor, which allows you to edit such files or create a new one directly as you edit the rule. This is what the panel left of the XPath expression area is for.
See also [the test framework documentation](pmd_userdocs_extending_testing.html).
### Testing model
A rule test describes
* the configuration of the rule
* the source on which to run
* the expected violations
* a description (to name the test)
When executing a test, the rule is run on the source with the given configuration, then the violations it finds are compared to the expected ones.
### Adding tests
Tests can be added in one of four ways:
* **From an XML file:** if you already have a test XML file for your tests, you can load all the tests it defines easily.
{% details Test import demo %}
![Test import example](images/designer/tests/import.gif)
{% enddetails %}
* **From the current source:** A new test case with a default configuration is created, with the source that is currently in the editor
* **With an empty source:** A new test case with a default configuration is created, with an empty source file. You must edit the source yourself then.
* **From an existing test case:** Each test case list item has a "Copy" button which duplicates the test and loads the new one.
### Test status
In the designer, the test panel is a list of test cases. Their status (passing, failing, error, unknown) is color coded.
{% details Test status color coding examples %}
All tests passing (green):
![All green](images/designer/tests/all-green.png)
A failing test (orange):
![Failing](images/designer/tests/failing.png)
{% enddetails %}
### Loading a test case
Each test has a piece of source, which you can edit independently of the others, when the test is **loaded in the editor**. Additional rule configuration options can be chosen when the test is loaded.
Loading is done with the **Load** button:
{% details Test loading demo %}
![Test loading demo](images/designer/tests/load.gif)
{% enddetails %}
Only one test case may be loaded at a time. If the loaded test is unloaded, the editor reverts back to the state it had before the first test case was loaded.
### Editing a loaded test case
When a test is loaded, *the source you edit in the code area is the source of the test*. Changes are independent from other tests, and from the piece of source that was previously in the editor.
When a test is loaded, an additional toolbar shows up at the top of the code area:
![Failing](images/designer/tests/toolbar.png)
#### Expected violations
The **"Expected violations"** button is used to add or edit the expected violations.
Initially the list of violations is empty. You can add violations by **dragging and dropping nodes** onto the button or its popup, from any control that displays nodes. For example:
{% details Adding a violation demo %}
![Add violation gif](images/designer/tests/add-violation.gif)
{% enddetails %}
#### Test case rule configuration
Rule properties can be configured for each test case independently using the **"Property mapping"** button. For example:
{% details Test rule property demo %}
![Configure properties demo](images/designer/tests/property.gif)
{% enddetails %}
This configuration will be used when executing the test to check its status.
### Exporting tests
When you're done editing tests, it's a good idea to save the test file to an XML file. Exporting is done using the **"Export"** button above the list of test cases:
{% details Test export demo %}
![Test export demo](images/designer/tests/export.gif)
{% enddetails %}
Note that the exported file does not contain any information about the rule. The rule must be in a ruleset file somewhere else.
If you want to use PMD's test framework to use the test file in your build, please refer to the conventions explained in [the test framework documentation](pmd_userdocs_extending_testing.html#where-to-place-the-test-code).

View File

@ -14,6 +14,12 @@ This is a {{ site.pmd.release_type }} release.
### New and noteworthy
#### New rule designer documentation
The documentation for the rule designer is now available on the main PMD documentation page:
[Rule Designer Reference](pmd_userdocs_extending_designer_reference.html). Check it out to learn
about the usage and features of the rule designer.
### Fixed Issues
* java-codestyle