Skip to content

SchweizerischeBundesbahnen/ch.sbb.polarion.extension.pdf-exporter

Repository files navigation

Quality Gate Status Bugs Code Smells Coverage Duplicated Lines (%) Lines of Code Reliability Rating Security Rating Maintainability Rating Vulnerabilities

Polarion ALM extension to convert Documents to PDF files

This Polarion extension provides possibility to convert Polarion Documents to PDF files. This is an alternative to native Polarion's solution. The extension uses WeasyPrint as a PDF engine and requires it to run in Docker as Service.

Important

Starting from version 8.0.0 only latest version of Polarion is supported. Right now it is Polarion 2410.

Quick start

Please see separate quick start page where briefly summarized all most important and applicable steps and configurations.

If you need deeper knowledge about all possible steps, configurations and their descriptions, please see sections below.

Build

This extension can be produced using maven:

mvn clean package

Installation to Polarion

To install the extension to Polarion ch.sbb.polarion.extension.pdf-exporter-<version>.jar should be copied to <polarion_home>/polarion/extensions/ch.sbb.polarion.extension.pdf-exporter/eclipse/plugins It can be done manually or automated using maven build:

mvn clean install -P install-to-local-polarion

For automated installation with maven env variable POLARION_HOME should be defined and point to folder where Polarion is installed.

Changes only take effect after restart of Polarion.

Polarion configuration

WeasyPrint configuration

This extension supports the use of WeasyPrint as a REST service within a Docker container, as implemented here. To change WeasyPrint Service URL, adjust the following property in the polarion.properties file:

ch.sbb.polarion.extension.pdf-exporter.weasyprint.service=http://localhost:9080

PDF exporter extension to appear on a Document's properties pane

  1. Open a project where you wish PDF Exporter to be available
  2. On the top of the project's navigation pane click βš™ (Actions) βž™ πŸ”§ Administration. Project's administration page will be opened.
  3. On the administration's navigation pane select Documents & Pages βž™ Document Properties Sidebar.
  4. In opened Edit Project Configuration editor find sections-element:
    …
    <sections>
      <section id="fields"/>
      …
    </sections>
    …
  5. And insert following new line inside this element:
    …
    <extension id="pdf-exporter" label="PDF Exporter" />
    …
  6. Save changes by clicking πŸ’Ύ Save

PDF Exporter view to open via button in toolbar

Alternatively you can configure PDF Exporter such a way that additional toolbar will appear in document's editor with a button to open a popup with PDF Exporter view.

  1. Open "Default Repository".
  2. On the top of its navigation pane click βš™ (Actions) βž™ πŸ”§ Administration. Global administration page will be opened.
  3. On the administration's navigation pane select Configuration Properties.
  4. In editor of opened page add following line:
    scriptInjection.dleEditorHead=<script src="/polarion/pdf-exporter/js/starter.js"></script><script>PdfExporterStarter.injectToolbar();</script>
    There's an alternate approach adding PDF Exporter button into native Polarion's toolbar, which has a drawback at the moment - button disappears in some cases (for example when document is saved), so using this approach is not advisable:
    scriptInjection.dleEditorHead=<script src="/polarion/pdf-exporter/js/starter.js"></script><script>PdfExporterStarter.injectToolbar({alternate: true});</script>
  5. Save changes by clicking πŸ’Ύ Save

PDF Exporter view to open in Live Reports

Live Reports also can be converted to PDF with help of this extension.

First of all you need to inject appropriate JavaScript code into Polarion:

  1. Open "Default Repository".
  2. On the top of its navigation pane click βš™ (Actions) βž™ πŸ”§ Administration. Global administration page will be opened.
  3. On the administration's navigation pane select Configuration Properties.
  4. In editor of opened page add following line:
    scriptInjection.mainHead=<script src="/polarion/pdf-exporter/js/starter.js"></script>
  5. Save changes by clicking πŸ’Ύ Save

Then open a project, its Live Report you wish to export, and click "Expand Tools" on top of the page. As a result report's toolbar will appear. Click "Edit" button in a toolbar, as a result the report will be switched into an edit mode. Add an empty region on top of the report, place cursor there, choose "PDF Export" tag on "Widgets" sidebar on right hand side of the page, find "Export to PDF Button" widget there and click it to add to the report. Then save a report clicking πŸ’Ύ in a toolbar and then return to a view mode clicking "Back" button. When you click "Export to PDF" button just added to the report, PDF Exporter view will be opened in a popup and you will be able to proceed with exporting the report to PDF. Be aware that in report's context limited set of properties are available for configuration in PDF popup, the rest of them are relevant only in Live Document context.

Bulk PDF Export

There is a possibility to export multiple documents in one run. This can be achieved with help of special widget.

Open a project where you wish do bulk export. Open its Default Space in Documents & Pages and create Live Report with name "Bulk PDF Export". Newly created report will be opened in edit mode. Change its title to "Bulk PDF Export" or whatever value you wish, then place cursor in a region you wish the widget to appear, choose "PDF Export" tag on "Widgets" sidebar on right hand side of the page, find "Bulk PDF Export" widget there and click it to add to the report. Then save a report clicking πŸ’Ύ in a toolbar and then return to a view mode clicking "Back" button.

As a result you will see a table listing all Live Documents in a current project (with pagination). This widget is an extension of standard Polarion table with a data set and can be configured the similar way, for example you can specify a Lucene query to narrow list of displaying documents, change set of columns or modify soring rule.

When you are ready with filtering, sorting etc. of documents you can select multiple documents to be exported, ticking appropriate checkboxes and click Export to PDF button, a popup with export configuration will be opened. Select appropriate configuration and click Export button, new popup will be opened showing progress of exporting. When export is finished click Close button to hide popup. Also, you can click Stop button when export is in progress, in this case document which is exporting at the moment will finish and the rest which were pending will be cancelled.

Configuring logs

For better problem analyses extended logging can be configured in Polarion. By default, Polarion log level is set to INFO. It can be changed to debug in log4j2.xml file. Find /opt/polarion/polarion/plugins/com.polarion.core.util_<version>/log4j2.xml file and add the following line into Loggerssection:

<Logger name="ch.sbb.polarion.extension" level="debug"/>

It is also possible to write all messages of SBB extensions info separate log file which can be useful to report a problem. In this case new Appender should be added:

<RollingFile name="SBB" fileName="${sys:logDir}/log4j-sbb${fileNameSuffix}" filePattern="${sys:logDir}/log4j-sbb${filePatternSuffix}">
    <PatternLayout pattern="${layoutPattern}"/>
    <Policies>
        <TimeBasedTriggeringPolicy interval="1"/>
    </Policies>
</RollingFile>

and the following Logger:

<Logger name="ch.sbb.polarion.extension" level="debug">
    <AppenderRef ref="SBB"/>
</Logger>

Enabling CORS

Cross-Origin Resource Sharing could be enabled using standard configuration of Polarion REST API. In polarion.properties the following lines should be added:

com.siemens.polarion.rest.enabled=true
com.siemens.polarion.rest.cors.allowedOrigins=http://localhost:8888,https://anotherdomain.com

Enabling webhooks

By default, webhooks functionality is not enabled in PDF Exporter. If you want to make it available the following line should be added in polarion.properties:

ch.sbb.polarion.extension.pdf-exporter.webhooks.enabled=true

Debug option

This extension makes intensive HTML processing to extend similar standard Polarion functionality. There is a possibility to log original and resulting HTML to see potential problems in this processing. This logging can be switched on (true value) and off (false value) with help of following property in file polarion.properties:

ch.sbb.polarion.extension.pdf-exporter.debug=true

If HTML logging is switched on, then in standard polarion log file there will be following lines:

2023-09-20 08:42:13,911 [ForkJoinPool.commonPool-worker-2] INFO  util.ch.sbb.polarion.extension.pdf_exporter.util.HtmlLogger - Original HTML fragment provided by Polarion was stored in file /tmp/pdf-exporter10000032892830031969/original-4734772539141140796.html
2023-09-20 08:42:13,914 [ForkJoinPool.commonPool-worker-2] INFO  util.ch.sbb.polarion.extension.pdf_exporter.util.HtmlLogger - Final HTML page obtained as a result of PDF exporter processing was stored in file /tmp/pdf-exporter10000032892830031969/processed-5773281490308773124.html

Here you can find out in which files HTML was stored.

PDF Variants configuration

This configuration property allows selecting a PDF variant to be used for PDF generation. The following variants are supported:

Variant Description
pdf/a-1b Basic visual preservation (older PDF standard)
pdf/a-2b Basic visual preservation with modern features like transparency
pdf/a-3b Visual preservation with file attachments
pdf/a-4b Visual preservation using PDF 2.0 standard
pdf/a-2u Visual preservation + searchable text (Unicode)
pdf/a-3u Visual preservation + searchable text with file attachments
pdf/a-4u Searchable text + PDF 2.0 features
pdf/ua-1 Accessible PDF for assistive technologies

To configure the PDF variant, adjust the following property in the polarion.properties file:

ch.sbb.polarion.extension.pdf-exporter.weasyprint.pdf.variant=pdf/a-2b

The default value is pdf/a-2b.

Workflow function configuration

It is possible to configure the workflow function which exports a PDF file and attaches it to a newly created or already existing work item.

To create workflow functions do following:

  1. On the top of the project's navigation pane click βš™ (Actions) βž™ πŸ”§ Administration. Project's administration pane will be opened.
  2. On the administration's navigation pane select Documents & Pages βž™ Document Workflow.
  3. On the opened page you will see a list of document types with their actions. Find type you are interested in and click Edit or Create button for it.
  4. On the opened page (Workflow Designer) find the section Actions, appropriate action in it, e.g. archive (or create a new one) and click Edit for it.
  5. A popup will be opened with title 'Details for Action: Archive', select 'PDF Export' in 'Function' dropdown of 'Functions' section and then click pencil button. Another popup will be opened with title 'Parameter for: PDF Export', add appropriate parameters in table of this popup, then click Close. Then again Close on previous popup and finally Save when you will be back on Workflow Designer page.

Supported function parameters:

Parameter Required Description Default value
existing_wi_id yes (*) Workitem ID to reuse -
create_wi_type_id yes (*) Type ID of workitem to create -
create_wi_title no Value to set as a workitem title (used only with 'create_wi_type_id') Value like "modified document title with space -> target status name" (e.g., "Specification / Product Specification -> Archived")
create_wi_description no Value to set as a workitem description (used only with 'create_wi_type_id') "This item was created automatically. Check 'Attachments' section for the generated PDF document."
project_id no Project ID where to create or search for the target work item Project ID of the modified document
attachment_title no The title of the attached file The name of the generated file (without '.pdf' at the end)
style_package no The name of the style package to use Default
prefer_last_baseline no Use the last baseline revision instead of the last document's revision false
(*) - either 'existing_wi_id' or 'create_wi_type_id' parameter required.
Providing the first one means reuse already existing workitem to attach the file whereas the second will create a new workitem with the specified type.
In case if both of them specified 'existing_wi_id' has higher priority.

Extension configuration

  1. On the top of the project's navigation pane click βš™ (Actions) βž™ πŸ”§ Administration. Project's administration page will be opened.
  2. On the administration's navigation pane select PDF Export. There are expandable sub-menus with different configuration options for PDF Exporter.
  3. For some of these options (Cover page, Header and Footer, Localization, Webhooks and Filename template) Quick Help section available with option short description. For the rest (Style package, Stylesheets) there's no Quick Help section as their content is self-evident.
  4. To change configuration of PDF Exporter extension just edit corresponding section and press Save button.

Usage

  1. Open a document in Polarion.
  2. In the toolbar choose Show Sidebar βž™ Document Properties.
  3. Choose desired options in the PDF Exporter block and click Export to PDF. For the options details please refer plugin documentation.

REST API

This extension provides REST API. OpenAPI Specification can be obtained here.

Advanced configuration

Asynchronous PDF Export: export jobs timeout

This extension provides REST API to export PDF asynchronously. Using this API, it is possible to start export job, observe their status and get result. Finished (succeed or failed) and in-progress export jobs will be preserved in memory until configured timeout. To change this timeout, adjust the following property in the local pdf-converter-jobs.properties file:

# Timeout in minutes to keep finished async conversion jobs results in memory
jobs.timeout.finished.minutes=30
# Timeout in minutes to wait until async conversion jobs is finished
jobs.timeout.in-progress.minutes=60

Known issues

All good so far.

Upgrade

Upgrade from version 7.x.x to 8.0.0

In version 8.0.0 support for Polarion 2404 and older has been dropped. This extension supports only Polarion 2410. Recommended version of WeasyPrint Service is 63.1.0.

Upgrade from version 6.x.x to 7.0.0

In version 7.0.0 /export-filename REST API endpoint changed. As a result, if the endpoint has been used, it's required to adjust the calls accordingly.

DocumentType enum in ExportParams has been changed. As a result, if enum values have been used, it's required to adjust the calls accordingly.

Main package has been renamed from ch.sbb.polarion.extension.pdf.exporter to ch.sbb.polarion.extension.pdf_exporter. As a result, if the extension has been used in another OSGi bundles, it's required to adjust the package imports accordingly.

There was also added a CSS fragment for better display of Test Run pages in PDF, please add this fragment to your CSS definitions if they differ from default one, or update your CSS definitions via UI clicking button "Default" and later saving it. Here is this fragment:

#polarion-rp-widget-content > .polarion-TestRunOverviewWidget-table > tbody > tr > td:first-child {
   width: 46% !important;
}
.polarion-TestRunOverviewWidget-buttonName {
   padding-top: 20px;
}

In version 7.1.0 the property ch.sbb.polarion.extension.pdf-exporter.internalizeExternalCss has been removed. polarion.properties should be updated accordingly.

Upgrade from version 5.x.x to 6.0.0

In version 6.0.0 WeasyPrint CLI support was removed. As a result, if WeasyPrint CLI has been using to generate PDFs, it's required to switch to WeasyPrint Service.

The configuration properties ch.sbb.polarion.extension.pdf-exporter.weasyprint.connector and ch.sbb.polarion.extension.pdf-exporter.weasyprint.executable have been removed due to the removal of WeasyPrint CLI support. polarion.properties should be updated accordingly.

Upgrade from version 4.x.x to 5.0.0

In version 5.0.0 not only label of configuration parameter "Fit images and tables to page width" was modified to be "Fit images and tables to page", but also underlying parameter was renamed to reflect this change. As a result if you had "Fit images and tables to page width" ticked in your configuration prior to version 5.0.0, after installation of this version you will have to go to configuration again and re-tick property "Fit images and tables to page", both on global repository level and on level of projects.

Another change is default CSS which was modified to reflect different possible paper sizes as well as additional styling for images to jump into next page if they can't be fully displayed on current one. Thus please either reset your saved CSS into last version if you didn't have your own CSS definitions or merge your saved version with new default version.