pentaho-kettle

Pentaho 数据集成(ETL),也称为 Kettle,提供强大的提取、转换和加载(ETL)功能。【 Pentaho’s Data Integration, also known as Kettle, delivers powerful extraction, transformation, and loading (ETL) capabilities. 】

Github星跟蹤圖

Pentaho Data Integration

Pentaho Data Integration ( ETL ) a.k.a Kettle

Project Structure

  • assemblies:
    Project distribution archive is produced under this module
  • core:
    Core implementation
  • dbdialog:
    Database dialog
  • ui:
    User interface
  • engine:
    PDI engine
  • engine-ext:
    PDI engine extensions
  • plugins:
    PDI core plugins
  • integration:
    Integration tests

How to build

Pentaho Data Integration uses the maven framework.

Pre-requisites for building the project:

  • Maven, version 3+
  • Java JDK 1.8
  • This settings.xml in your /.m2 directory

Building it

This is a maven project, and to build it use the following command

$ mvn clean install

Optionally you can specify -Drelease to trigger obfuscation and/or uglification (as needed)

Optionally you can specify -Dmaven.test.skip=true to skip the tests (even though
you shouldn't as you know)

The build result will be a Pentaho package located in target.

Running the tests

Unit tests

This will run all unit tests in the project (and sub-modules). To run integration tests as well, see Integration Tests below.

$ mvn test

If you want to remote debug a single java unit test (default port is 5005):

$ cd core
$ mvn test -Dtest=<<YourTest>> -Dmaven.surefire.debug

Integration tests

In addition to the unit tests, there are integration tests that test cross-module operation. This will run the integration tests.

$ mvn verify -DrunITs

To run a single integration test:

$ mvn verify -DrunITs -Dit.test=<<YourIT>>

To run a single integration test in debug mode (for remote debugging in an IDE) on the default port of 5005:

$ mvn verify -DrunITs -Dit.test=<<YourIT>> -Dmaven.failsafe.debug

To skip test

$ mvn clean install -DskipTests

To get log as text file

$ mvn clean install test >log.txt

IntelliJ

  • Don't use IntelliJ's built-in maven. Make it use the same one you use from the commandline.
    • Project Preferences -> Build, Execution, Deployment -> Build Tools -> Maven ==> Maven home directory

Contributing

  1. Submit a pull request, referencing the relevant Jira case
  2. Attach a Git patch file to the relevant Jira case

Use of the Pentaho checkstyle format (via mvn checkstyle:check and reviewing the report) and developing working
Unit Tests helps to ensure that pull requests for bugs and improvements are processed quickly.

When writing unit tests, you have at your disposal a couple of ClassRules that can be used to maintain a healthy
test environment. Use RestorePDIEnvironment
and RestorePDIEngineEnvironment
for core and engine tests respectively.

pex.:

public class MyTest {
  @ClassRule public static RestorePDIEnvironment env = new RestorePDIEnvironment();
  #setUp()...
  @Test public void testSomething() { 
    assertTrue( myMethod() ); 
  }
}

Asking for help

Please go to https://community.hitachivantara.com/community/products-and-solutions/pentaho/ to ask questions and get help.

主要指標

概覽
名稱與所有者pentaho/pentaho-kettle
主編程語言Java
編程語言Shell (語言數: 7)
平台Linux, Mac, Windows
許可證Other
所有者活动
創建於2013-10-08 18:27:11
推送於2025-04-22 00:15:07
最后一次提交2025-04-21 16:58:04
發布數2180
最新版本名稱10.2.0.3-331 (發布於 2025-04-22 00:15:03)
第一版名稱2.2.2 (發布於 )
用户参与
星數8k
關注者數457
派生數3.5k
提交數23.9k
已啟用問題?
問題數0
打開的問題數0
拉請求數8806
打開的拉請求數65
關閉的拉請求數1090
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?