Major new features
- Added tool to create a DQMH API Tester for Cloneable DQMH Modules running on a LabVIEW RT Target –> Based on requests like this one here.
- Added tool to create New Unit Tests for existing events
- Added #DQMH_HowTo bookmarks to Main VIs, API Testers and shipping examples with How-To information, including how the different events were created, and links to youtube videos
- New Validate DQMH Tools to upgrade existing DQMH modules to DQMH 4.0 as seen in this video
- Updated New Module tool to allow for absolute paths in the metadata XML for a DQMH module template. If the <AbsolutePaths>TRUE</AbsolutePaths> tag is present, then the LocationPath entry will be ignored, and the code assumes the paths for the library and the tester tags are absolute. –> as requested here
- Added tool to create a DQMH API Tester for Cloneable DQMH Modules running on a LabVIEW RT Target.
Project Template
- Modified the template VIs to not have the Update Display status and instead call the Status updated broadcast. –> This is to follow one of our own Best Practices of calling atomic operations directly instead of enqueuing several operations because we cannot guarantee that nothing else is enqueued in between.
- Removed the Show Panel, Hide Panel, and Show Diagram messages from the MHL. Added two new subVIs, Open VI Panel.vi and Hide VI Panel.vi. They are private to the module. And the Show/Hide Panel events call those subVIs (and also broadcast messages about the panel being shown/hidden. And Moved the Show Diagram code from the MHL into the Show Diagram event case. With this approach, we solve the issue of the MHL being locked out from show/hide panel, and we provide utility subVIs for showing/hiding the panel that any other message can call to make its operation atomic. –> Following our own Best Practices of calling atomic operations.
- Added handling of error output from Register For Events function in Main VI of all three libraries in DQMH project template.
- Updated Close Module.vi in both libraries to fire the Module Did Stop broadcast even if there is an incoming error.
- Updated Singleton and Cloneable Main VIs in the project template to pass the queue class wire around the event structure in the EHL instead of passing it through.
- Updated Singleton tester to remove race condition of front panel being reinitialized and the Module Running local variable being updated. Also updated Cloneable tester to use the same arrangement for consistency
- Updated code in Panel Close event to call the new Hide VI Panel VI and no longer call the Confirm Quit message. Removed Confirm Quit message from MHL
- Updated both testers to use the ‘init’ parameter of the Module Did Init broadcast to add either a ‘succeeded’ or ‘failed’ message to the status display
- Updated Handle Exit VI to call the new Hide VI Panel VI, and to not wire the error terminals of the VI
- Updated Singleton tester to remove race condition of front panel being reinitialized and the Module Running local variable being updated. Also updated Cloneable tester to use the same arrangement for consistency. –> Based on feedback given here
DQMH Scripter
Specific for LabVIEW RT Support:
- Added scripting support for RT API Tester for cloneable modules
- New DQMH Real-Time Tools>>Create RT Tester makes a copy of existing tester with -RT.vi file name suffix and tags the copy with an RT tester-specific tag
- Scripting code puts RT copy next to existing tester in the project. If not found, puts it next to module library
- DQMH API Tester for RT removes post-loop code that stops the module. Updates free label to mention use case for leaving RT tester dormant
- DQMH API Tester for RT removes Or for the error cluster, and adds an error out local variable
- Value Change events are not supported in RT, nor Panel Close? events. These events are not present in DQMH API Tester for RT
- DQMH API Tester for RT has logic in Timeout event with default buttons (Start, Stop, Refresh, Exit), polls for buttons and has a case structure with a frame for each one of all the existing public requests in the cloneable module
- Scripting code adds a #CodeNeeded bookmark in each case frame so the user can wire in whatever inputs they need to the public request in order to properly test it
- The tool scripts latching button on the panel for each public request VI
- The tool skips scripting for “Hide Panel”, “Show Panel”, and “Show Diagram” since they don’t have a meaning in an RT Tester
- Added ability to have new events create appropriate code in both the traditional DQMH API Tester and the DQMH API Tester for RT
- Changed Arguments Window to be a VI created in the temp folder that is deleted after event scripting is done. This allows us to discard any errant saved changes to the Arguments Window made during its use
- There are now validate/fix tools for a module folder with multiple VIs tagged as Main, Tester, or RT Tester
- Fixed bug where DQMH scripting was attempting to set the subdiagram label of any subdiagram in any generated code where the label hasn’t ever been shown
- Fixed a “bug” with scripting where a VI was being erroneously identified as the tester VI for a module
- Added pre-flight check for New Event scripting to pop up a dialog if the Arguments Window has a control named ‘Module ID’ in it, since the DQMH scripting tools use that as a reserved control name for scripting operations
- Updated ‘Remove Event’ code to look for the removed event’s MHL frame name in quotes when looking for the frame to drop the code review todo comment inside
- Resized the result string indicator in the Validate Module results UI so it doesn’t overlap the Fix Issue button
- Added code to Rename Module scripting that updates VI descriptions to only update the following situations:
- [Module Name] at the beginning of the description
- [Module Name] in between space characters
- [Module Name].lvlib
- Updated ‘module did init’ event frame in API testers to use the ‘init’ event parameter to change the status message display based on its value: TRUE: append ‘ initialization succeeded.’ to the info parameter; FALSE: append ‘ initialization failed.’ to the info parameter
- Fixed New Event scripting to be able to handle the situation where the user has a child class of the DQMH Queue in their Main VI so that event structure scripting works correctly
- Updated singleton and cloneable Main VIs in the project template to pass the queue class wire around the event structure in the EHL instead of passing it through. This also required changes to the scripting code to account for the fact that the event structure will sometimes have a queue class wire going through the frame, and sometimes it won’t
- Updated popup dialog message when specifying an event name that conflicts with an existing VI in the library to make it more clear that there is a more general filename conflict, as opposed to an event name conflict
- Changed recursive file list to top-level folder list when checking to see if a proposed event name is valid. This way if there is a lower level folder for a class, it can have VIs with the same name as the Request or Broadcast VIs
- Made Remove Event, Rename Event, and Rename Module dialogs modal
- Improved performance of New Module and Rename Event tools
- Added the ability for the Create New DQMH Module tool to reference template modules by absolute path
- Whenever the user enters a string for the event name or the broadcast name in a round trip, trim whitespace at the time the value is committed
- Fixed module list ring in all DQMH scripting tools to not list duplicate module entries when the same module appears under multiple targets in the project –> as reported here
- Creating a Request and Wait for Reply event places the event parameter control terminals on the top-level diagram in the fire event VI
- Fixed scripting bug (error 1314) that was trying to update labels of constants inside typedefs when creating a module from the template.
- Updated New Module tool to allow for absolute paths in the metadata XML for a DQMH module template. If the <AbsolutePaths>TRUE</AbsolutePaths> tag is present, then the LocationPath entry will be ignored, and the code assumes the paths for the library and the tester tags are absolute. –> as requested here
- Added support for scripting a new module into an auto-populating folder in the project. –> as reported here
New Validate/Fix DQMH Module Tools for:
- Finding obsolete Show Panel, Hide Panel, and Show Diagram message frames
- Finding and fixing untagged Request and Wait for Reply VIs (needed for Delacor VI Analyzer custom tests)
- Detecting and fixing the old error handling in Close Module.vi
- Added a new validate/fix tool for the Handle Exit case that inserts a clear Errors on the output of the FP.Open method, since this can error out when called in a Real-Time system
- Added Validate test for message strings being wired into DQMH Enqueue Message that do not have corresponding frames in the MHL case structure. When reporting, enclose result strings in quotes so bad message strings with preceding or trailing whitespace can be more easily identified. Added a new validate tester for finding string constants in the DQMH Main VI containing invalid message names (such as an empty string)
- Fixed bug in ‘Sending Nonexistent Messages’ Validate Module tester that was getting in an infinite loop when the DQMH Enqueue Message (poly).vi was inside a structure and its ‘message’ input was being sourced by a structure tunnel. (Please Note that the DQMH Enqueue Message (poly).vi does have an array messages implementation)
- Added Validate Module test to detect an unwired error output on the Register for Events node in the module Main VI
- Added a validate module tester to detect Reply Payload typedefs that do not contain error clusters
- Updated progress dialog of Validate Module tool to display the name of the current test being run, not only to help users see progress but also help Delacor know whenever the Validation tool hangs, which test was running when it hung
- Added a new validate tester and fixer for handling multiple VIs in a module tagged as testers, RT testers, or main VIs
DQMH Thermal Chamber Examples
Updated videos in documentation for shipping examples
- Validated for DQMH 4.0 and updated to match DQMH 4.0
- TestStand: Renamed Local variables Temperature_Set_Point and Temperature_Set_Points to be Current_Temperature_SetPoint and Temperature_SetPoint_List. Both are more descriptive and less likely to cause confusion while editing sequence steps
- TestStand: Replaced the Do-While with For-Each Loop since the code is looping through arrays of values that are not dynamic during looping.
- TestStand: Removed Locals.TempAsString variable, it had no purpose as a variable that is not satisfied just by the numeric value that we already had, moving the conversion to where it is needed
- TestStand: Disabled Result Recording at the sequence level and Force enabled the required steps in sequence. The previous approach of disabling every step result except one led to a very cluttered sequence view
- TestStand: Edited sequence file properties to select the required Model file instead of modifying the TestStand station options programmatically. This respects the TestStand station options the people trying out our DQMH examples have. Updated the welcome message
- Set TestStand reports to be HTML instead of XML. Introduced the ReportOptions Sequence File Callback to pass the Report Format, Directory Type, and Directory Path. Changed the Find TestReport Directory.vi to create the DQMHTS Reports folder if it is not present
- TestStand: Edited each sequence file to have a specific sequence model. None for the Thermal Chamber sequence, since it does not have a unit under test. Sequence Model for the sequence with a single unit under test. Batch model for the sequence with multiple units under test. This approach respects the current station options configurations and does not change them. Updated the welcome dialog and notes in the sequence files to reflect these changes
- TestStand: Deleted steps that were marked as skip, they were no longer used
- TestStand: Fixed spelling error on subsequence name
- TestStand: Strengthened the logic when searching for the Delacor examples path to ensure it only searches for configured paths and not a TestStand autogenerated paths
- TestStand: Configure the number of sockets to 2 for the Batch sequence instead of using what is currently on the station
- LabVIEW: Added Check Execution Status Case to the MHL. Added case Stop DQMH Modules
- LabVIEW: Updated the exit case to include the Close Termination Monitor.vi
- LabVIEW: Thermal Chamber Controller DQMH Status Updated.vi did not share the same Library header on its icon as ll the rest of the VIs in this library
Help
- Updated Change History section in help documentation
- Added section to the documentation that talks about the creation of DQMH API Tester for LabVIEW Real-Time
- Added section for DQMH for RT
- Added section for creating DQMH Unit Tests
- Added information on how to use absolute paths instead of relative paths when Adding a New DQMH Module from a Custom Template
- Added embedded videos with real-life examples of applications implemented using DQMH in the Use Cases section
- Updated TestStand examples video in section TestStand Examples
- Added new examples video in section LabVIEW Examples
- Moved DQMH Help button over one pixel to make it flush with right border