With 19.1, we've added some new features to our Python SDK!
FYI - ToolFamily is only applicable to tools built with the Python SDK. Previous versions of custom tools that do not include ToolFamily in the config XML files will continue working in Alteryx 19.1.
The purpose of ToolFamily is to consolidate virtual environments. This will save you space and allow you to logically group tools together, like connectors or machine learning tools, that share common Python packages. An example of using ToolFamily in the ToolNameConfig.xml file is below. If you have multiple Python SDK tools that you would like to share the same virtual environment (venv), specify a ToolFamily value that will be consistent across the tools. The venv will be installed in the same directory as the tools and it will be named ToolFamily_venv. For the example below, it will be a new folder named multitool_venv.
<?xml version="1.0"?>
<AlteryxJavaScriptPlugin>
<EngineSettings EngineDll="Python" ToolFamily ="multitool" EngineDllEntryPoint="Python - Single Input OutputEngine.py" SDKVersion="10.1" />
<GuiSettings Html="Python - Single Input OutputGui.html" Icon="Python - Single Input OutputIcon.png" Help="https://help.alteryx.com/developer/current/index.htm#Python/Examples.htm" SDKVersion="10.1">
<InputConnections>
<Connection Name="Input" AllowMultiple="False" Optional="False" Type="Connection" Label=""/>
</InputConnections>
<OutputConnections>
<Connection Name="Output" AllowMultiple="False" Optional="False" Type="Connection" Label=""/>
</OutputConnections>
</GuiSettings>
<Properties>
<MetaInfo>
<Name>Python - Single Input Output</Name>
<Description>Description for this tool.</Description>
<ToolVersion>1.0</ToolVersion>
<CategoryName>Laboratory</CategoryName>
<SearchTags>python, sdk, select, sample, top, records, python sdk</SearchTags>
<Author>Alteryx</Author>
<Company>Alteryx, Inc.</Company>
<Copyright>2017</Copyright>
</MetaInfo>
</Properties>
</AlteryxJavaScriptPlugin>
If you wish to package tools within the same ToolFamily in a single YXI, make sure the ToolFamily value in the outer Config.xml matches the ToolFamily within.
But what about the requirements.txt file, you may be asking? Can you get by with just one per ToolFamily? Technically, yes, but it is still good practice to include a requirements.txt for each tool. Your future self might thank you if you have to break the family up!
The DebugMessageOut method is a great way to add debug messages to your code and not have to worry about deleting or commenting them out once your tool is in production.
How to use it:
self.alteryx_engine.debug_message_out(self.n_tool_id,Sdk.EngineMessageType.info,"This is my python debugger")
In order to enable that message to appear in the Results window or console, the EnableDebugMessages constant must be set to True. In Alteryx, under the workflow tab of the Workflow-Configuration window, click the plus sign and type 'EnableDebugMessages' for the Name and set the value to True. If that constant is not defined for a workflow, that value is set to False by default.
I'm having trouble installing a YXI with multiple tools packaged together. All have the ToolFamily="Alight" in the EngineSetttings element (first position before EngineDll):
<?xml version="1.0"?>
<AlteryxJavaScriptPlugin>
<EngineSettings ToolFamily="Alight" EngineDll="Python" EngineDllEntryPoint="main.py" SDKVersion="10.1" />
...
And the Config.xml is written as follows. Did I include the ToolFamily correctly in this file?
<?xml version="1.0"?>
<AlteryxJavaScriptPlugin>
<Properties>
<MetaInfo>
<Name>Alight Tools</Name>
<RootToolName>Alight Tools</RootToolName>
<Description>Set of tools for ...</Description>
<CategoryName>Alight</CategoryName>
<ToolFamily>Alight</ToolFamily>
<ToolVersion>0.0.1</ToolVersion>
<Author>Cameron Willis</Author>
<Company>Company</Company>
<Copyright>2019</Copyright>
<SearchTags>python, sdk, alight, python sdk</SearchTags>
<Icon>AlightIcon.png</Icon>
</MetaInfo>
</Properties>
</AlteryxJavaScriptPlugin>
As of the moment, I'm still getting the following error message when I install in Designer 2019.2:
“The installation failed. ToolFamily must match for all tools included a yxi file.”
Cameron
For others with similar questions about ToolFamily --
I found that the EngineSettings tag needs to be included in the Config.xml file which previously was not needed. For example, below is the Config.xml file from the ML Tools Installer:
<?xml version="1.0" encoding="utf-8"?>
<AlteryxJavaScriptPlugin>
<EngineSettings EngineDll="Python" ToolFamily="MachineLearningTools" SDKVersion="10.1"></EngineSettings>
<Properties>
<MetaInfo>
<Name>ml_tools</Name>
<RootToolName>ml_tools</RootToolName>
<Description>Python Machine Learning Tools</Description>
<CategoryName>ML Tools</CategoryName>
<ToolVersion>0.0.0.153726</ToolVersion>
<Author>Alteryx, Inc.</Author>
<Company>Alteryx, Inc.</Company>
<Copyright>2019</Copyright>
<SearchTags>scikit-learn, python, predictive, machine, learning</SearchTags>
<Icon>icon.png</Icon>
</MetaInfo>
</Properties>
</AlteryxJavaScriptPlugin>