Skip to content

Latest commit

 

History

History
398 lines (270 loc) · 16.5 KB

developer_guide.md

File metadata and controls

398 lines (270 loc) · 16.5 KB

Developer Guide

This developer guide describes how to

  • Test the connectors manually
  • Run Tableau's TDVT test suite
  • Run UI tests for Tableau Server

Manually Testing Connectors

Tableau Desktop

To manually test the connectors in Tableau Desktop without packaging, add the following arguments when starting Tableau Desktop:

"C:\Program Files\Tableau\Tableau 2022.2\bin\tableau.exe" -DConnectPluginsPath=%USERPROFILE%\git\tableau-connector\src -DLogLevel=Debug
  • -DConnectPluginsPath=path\to\tableau-connector\src: Path to the src directory of this cloned repository.
  • -DLogLevel=Debug: enable log output of logging.Log() in JavaScript files.

After starting Tableau Desktop, click More... in the left bar under "To a Server", then click Exasol JDBC by Exasol AG or Exasol ODBC by Exasol AG to open the database connection dialog for JDBC resp. ODBC.

Restart Tableau after modifying any connector file to reload changes.

Tableau Server

To allow using unsigned connectors, run

tsm configuration set -k native_api.disable_verify_connector_plugin_signature -v true --force-keys
tsm pending-changes apply --ignore-prompt

Package the connectors as described below then copy them to C:\Program Files\Tableau\Connectors (Windows) or /var/opt/tableau/tableau_server/data/tabsvc/vizqlserver/Connectors/ (Linux) and restart Tableau Server:

./tools/package_connector.sh
# Linux:
cp -v target/*.taco /var/opt/tableau/tableau_server/data/tabsvc/vizqlserver/Connectors/
# Windows:
cp -v target/*.taco "/c/Program Files/Tableau/Connectors"
tsm restart

Verify Database Metadata

To verify details about the Exasol database or which user account Tableau is using for connecting to Exasol, create the following views and check their content from Tableau:

CREATE SCHEMA IF NOT EXISTS META;

CREATE OR REPLACE VIEW META.CURRENT_SESSION_INFO AS
   SELECT SESSION_ID, LOGIN_TIME, DURATION, USER_NAME AS SESSION_USER_NAME, CLIENT, DRIVER, ENCRYPTED
   FROM SYS.EXA_ALL_SESSIONS
   WHERE SESSION_ID=CURRENT_SESSION;

CREATE OR REPLACE VIEW META.DATABASE_INFO (KEY, VAL) AS
   SELECT 'DB Version', PARAM_VALUE FROM EXA_METADATA WHERE PARAM_NAME = 'databaseProductVersion';

CREATE OR REPLACE VIEW META.DATA_TYPES AS
  SELECT TYPE_NAME, PRECISION, CREATE_PARAMS, FIXED_PREC_SCALE, MINIMUM_SCALE, MAXIMUM_SCALE
  FROM SYS.EXA_SQL_TYPES;

Then add one of the views to a Tableau data source and add it to a workbook sheet.

Packaging the Connectors

Initial Setup

Prequisites for Linux

python3-venv and JDK 11 are required under Linux.

# Ubuntu:
sudo apt-get install python3-venv openjdk-11-jdk

Prerequisites for Windows

Download and install the following packages:

Building the Connector

To package the JDBC and ODBC connectors, execute the following command in a bash shell:

./tools/package_connector.sh

This validates the connectors and creates the .taco files at

target/exasol_jdbc.taco
target/exasol_odbc.taco

To use the connectors, copy them to

  • C:\Users\[Windows User]\Documents\My Tableau Repository\Connectors (Windows, Tableau Desktop)
  • C:\Program Files\Tableau\Connectors (Windows, Tableau Server)
  • /Users/[user]/Documents/My Tableau Repository/Connectors (macOS, Tableau Desktop)
  • /var/opt/tableau/tableau_server/data/tabsvc/vizqlserver/Connectors/ (Linux, Tableau Server)

As the connectors are not signed, you need to start Tableau Desktop with argument -DDisableVerifyConnectorPluginSignature.

Signing the Connectors

To sign the built connectors you will need the certificate as a .pfx file and the keystore password.

Run the following command after building the connectors:

./tools/sign_connector.sh /path/to/certificate.pfx

This will ask you to enter the keystore password and write the signed connector files to

target/tableau-exasol-connector-jdbc-<version>.taco
target/tableau-exasol-connector-odbc-<version>.taco

Run JavaScript Tests

Required Node Version

Installing test dependencies may fail with Node version 23 when compiling native library node-expat:

npm error In file included from ../node-expat.cc:1:
npm error ../../nan/nan.h:208:12: error: no template named 'CopyablePersistentTraits' in namespace 'v8'; did you mean simply 'CopyablePersistentTraits'?
npm error   208 |     public v8::CopyablePersistentTraits<T> {};
npm error       |            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~
npm error       |            CopyablePersistentTraits
npm error ../../nan/nan.h:207:7: note: 'CopyablePersistentTraits' declared here

Installing Node version 22 should fix the problem.

Run Tests

cd javascript-test
npm install
npm test

TDVT Tests

You can run TDVT tests under Windows and macOS. This guide describes the setup for Windows. The setup for macOS is similar.

Initial Setup

Install TDVT

TDVT library must be installed in a Python virtual environment (venv). The TDVT documentation describes how to do this.

However we provide a script that automatically clones and installs TDVT into a new venv at target/tdvt-venv:

./tools/setup_tdvt.sh

Script tools/run_tdvt_tests.sh will automatically use this venv.

Configure Test Suites

You can configure test suites to enable or disable tests using the following .ini files.

After modifying these files you need to re-generate the test suite by adding the --generate argument to the tdvt.tdvt run command. Script tools/run_tdvt_tests.sh uses this option by default.

See the manual for details about the available tests.

Run Tests

To run TDVT tests for the JDBC and ODBC connectors, run

./tools/run_tdvt_tests.sh

This will collect test results in target/tdvt_results_jdbc/ resp. target/tdvt_results_odbc/. Alternatively you can run the tests manually:

  • JDBC Connector:

    source target/tdvt-venv/Scripts/activate
    cd tdvt_jdbc
    python -m tdvt.tdvt run exasol_jdbc --generate
    python -m tdvt.tdvt run exasol_jdbc
  • ODBC Connector:

    source target/tdvt-venv/Scripts/activate
    cd tdvt_odbc
    python -m tdvt.tdvt run exasol_odbc --generate
    python -m tdvt.tdvt run exasol_odbc

See the manual for details.

Viewing Test Results

TDVT writes the test result to test_results_combined.csv. You can view it by opening the TDVT Results.twb workbook with Tableau Desktop. After re-running the tests type F5 to refresh the results. See detailed instructions.

Troubleshooting TDVT Tests

Log files of Tableau Desktop: %USERPROFILE%\Documents\My Tableau Repository\Logs\:

  • log.txt
  • jprotocolserver.log

Also see the FAQ and troubleshooting section of the manual.

Smoke Test Fail With Message Package signature verification failed during connection creation.

Error message in test_results_combined.csv:

LoadDatasource DataSourceException: Package signature verification failed during connection creation.

This could mean that a connector is already installed as a .taco file. Make sure to remove all .taco files from C:\Program Files\Tableau\Connectors.

Smoke Test Fail With Message Can't start FlexNet Licensing Service

Error message in test_results_combined.csv:

Can't start FlexNet Licensing Service (try setting automatic start)
LoadDatasource TableauException: Unable to establish connection: Data source 'Exasol JDBC by Exasol AG' has not been licensed.

This could mean that you are connecting the test machine via SSH. Start the tests by logging in to the machine directly.

Other Tests Fail

If TDVT tests fail follow these steps:

  1. View test results using the workbook or check file test_results_combined.csv, searching for text Actual does not match expected.

    Example failure:

    exasol_odbc,expression.standard.exasol_odbc,cast_calcs.exasol_odbc,string.space.empty,C:\Users\$USER\git\tableau-connector\target\connector-plugin-sdk\tdvt\tdvt\exprtests/standard\setup.string.space.empty.txt,False,0,1,SPACE(0),expression,unknown,unknown,unknown,,"Actual does not match expected. To run this test: 
    python -m run-pattern exasol_odbc --exp exprtests/standard/setup.string.space.empty.txt --tdp cast_calcs.exasol_odbc.tds",Actual does not match expected.,171.0,"
          SELECT CASE WHEN 0 < 1 THEN NULL WHEN 0 = 0 THEN '' ELSE REPEAT(' ',0) END AS ""TEMP_Test_______________""
    FROM ""TESTV1"".""Calcs"" ""Calcs""
    HAVING (COUNT(1) > 0)
    ",%null%,""""""
    

    The last two fields contain the actual and expected query results.

  2. Execute the query and verify the result.

  3. Open the test case in the TDVT repo (exprtests/standard/setup.string.space.empty.txt in this case with content SPACE(0)).

  4. Find the executed function in file dialect.tdd (SPACE) in this case.

  • If possible adjust the function definition.
  • If the failure is caused by an incompatibility of the Exasol database, exclude the test.

Excluding Tests

Some tests are expected to fail because the Exasol database behaves different than the expectations. A common example is that Exasol returns NULL instead of empty strings. In this case you can exclude the test.

In file config\exasol_jdbc.ini add the test name (string.space.empty in the example above) to section StandardTests / option ExpressionExclusions_Standard and add a rationale for the exclusion:

[StandardTests]
ExpressionExclusions_Standard = string.split,calcs_data.time,string.endswith.empty,string.startswith.empty,string.find.empty,string.space.empty

Tableau Server UI Tests

The UI tests verify that the Exasol connector works with Tableau Server.

Setup

  1. Follow the instructions to create a container. This should result in an image tableau_server_image:<version>, e.g. tableau_server_image:20213.21.0917.1006.

  2. Update tableau-server-GUI-tests/set_up_scripts/Dockerfile:

    • Use the same image created before in the FROM line, e.g. tableau_server_image:20213.21.0917.1006.
    • Update the download urls to the latest Exasol release if available.
  3. Update constant DEFAULT_DOCKER_DB_REFERENCE in class TableauServerGUITestIT to the latest Exasol release.

  4. Build a new container including the Exasol ODBC and JDBC drivers by running

    cd tableau-server-GUI-tests/set_up_scripts
    docker build . --tag tablau_server_with_exasol_drivers

Run the UI Tests

To run the tests you need to create the tableau-server-GUI-tests/src/test/resources/credentials.properties file with the following content (replace the placeholders for real values):

TABLEAU_USERNAME=<tableau-server-username>
TABLEAU_PASSWORD=<tableau-server-password>
TABLEAU_LICENSE_KEY=<tableau-server-license-key>

Start the tests with

cd tableau-server-GUI-tests
mvn integration-test

Run the Tests Remotely

Startup of the Tableau Server takes a long time. We recommend using an AWS instance running "Amazon Linux 2" with 16 CPUs, e.g. c5a.4xlarge. With this instance type, startup will take about 15 to 20 minutes instead of 30 minutes.

You can either run the tests completely on the remote machine or start them on your local machine.

Start tests on remote machine

This assumes you are using an AWS instance running Amazon Linux 2.

  1. Setup the instance with a UI as described here.
  2. Install a Chrome browser as this will be used for running the UI tests.
  3. Install Java 11 (yum install java-11-amazon-corretto) and the latest Maven version.
  4. Start the VNC server on the instance with vncserver -geometry 1920x1080.
  5. Tunnel the VNC server port via ssh <host> -L 5901:localhost:5901.
  6. Start a local VNC client and connect to localhost:5901.
  7. In the VNC session make sure you can start the chrome browser.
  8. Run the tests via mvn integration-test.

Start tests on local machine

If you want to trigger the tests from your local IDE, you need to forward the required ports and configure your local environment:

ssh ec2-user@<remote machine address> -i <ssh-key> -L 2375:localhost:2375 -L 33445:localhost:33445 -L 33446:localhost:33446

Specify the host where the docker daemon is running and disable the Ryuk container:

export DOCKER_HOST=tcp://localhost:2375
export TESTCONTAINERS_RYUK_DISABLED=true

Troubleshooting UI Tests

Tableau Server Startup Fails

Run tsm status -v to see the detailed status of all Tableau services.

Tableau Server Docker Container Startup Fails

When the Tableau server container stops after some minutes, you can start the container with environment variable TSM_ONLY=1, attach to the container and start the server with "${DOCKER_CONFIG}"/config/tsm-commands:

docker run --env TABLEAU_USERNAME=user --env TABLEAU_PASSWORD=password --env LICENSE_KEY=$license --env REQUESTED_LEASE_TIME=60 --env TSM_ONLY=1 --publish 8080:8080 --detach tablau_server_with_exasol_drivers:latest

See detailed troubleshooting instructions.

One possible root cause is an invalid license key. To check if the license is valid, run tsm licenses list in the container. You can try to activate a license with tsm licenses activate -k $license_key or get a trial license by running tsm licenses activate --trial.

Manually Testing Kerberos Authentication

Testing that Kerberos authentication works with the connector requires setting up a Windows Domain Controller and Active Directory. You can use the JDBC Kerberos setup test to verify Kerberos delegation works in your setup. We recommend using this if Kerberos authentication does not work with Tableau Server.

Building a Release

To build a release of the JDBC and ODBC connectors follow these steps:

  1. Update version number of the plugin-version element in the manifest files for JDBC and ODBC connectors:
  1. Run the TDVT tests for JDBC and ODBC connectors.
  2. Package and sign the JDBC and ODBC connectors.
  3. Create a new GitHub release and upload files
  • target/tableau-exasol-connector-jdbc-<version>.taco
  • target/tableau-exasol-connector-odbc-<version>.taco