Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Persist task id in ACT_HI_VARINST table for task variables #4578

Closed
1 task
jyotisahu9 opened this issue Sep 4, 2024 · 13 comments
Closed
1 task

Persist task id in ACT_HI_VARINST table for task variables #4578

jyotisahu9 opened this issue Sep 4, 2024 · 13 comments
Assignees
Labels
type:feature Issues that add a new user feature to the project.

Comments

@jyotisahu9
Copy link
Contributor

jyotisahu9 commented Sep 4, 2024

User Story (Required on creation)

As a Operations engineer, I would like to know all variables related to specific task

Functional Requirements (Required before implementation)

  • To be able to query all respective task variables using task id from history ACT_HI_VARINST tables

Technical Requirements (Required before implementation)

  • Save task id in existing TASK_ID_ column in history ACT_HI_VARINST table while persisting task variables (input variable or variable created through task or execution listener). Do not update column value if the variable belongs to process instance or any other component.

Pull requests

Preview Give feedback
  1. jyotisahu9
@jyotisahu9 jyotisahu9 added the type:feature Issues that add a new user feature to the project. label Sep 4, 2024
@psavidis psavidis self-assigned this Sep 6, 2024
@psavidis
Copy link
Contributor

psavidis commented Sep 6, 2024

Hi @jyotisahu9,

Could you explain further the Technical Requirements section?

It is not clear to me what is described there as well how it ties to the functional requirements section (being able to query all tasks variables from runtime and history tables)

@jyotisahu9
Copy link
Contributor Author

jyotisahu9 commented Sep 6, 2024

Hi @psavidis,

There is TASK_ID_ column in ACT_HI_VARINST table that remains null for task variable ( created through Execution listeners or task listeners). We would like to reuse this column to save task id to identify these variables related to specific task and query them.

There is VAR_SCOPE_ column in ACT_RU_VARIABLE table that persists the task id or process instance id to identify specific variable, but once that task is completed, entries are deleted from table.

Hope this clarifies the requirement. Let me know !!

Thanks,
Jyoti

@jyotisahu9
Copy link
Contributor Author

Hi @psavidis ,

Does this looks good to you? Do you have any questions?

Thanks,
Jyoti

@psavidis
Copy link
Contributor

Hello @jyotisahu9,
I'm currently occupied on items of high priority for the upcoming release.

I think i understood the requirement, the description / formatting looked a bit confusing to me.

In the meantime, could you break down the technical description into a list of high-level steps that describe what needs to be added? You could for example break it down into layers and mention the table (as you did), the query, the service involved, rest-api etc.

I will review it once i have time and make any necessary adjustments if needed. The goal is to have a technical description which reflects on a high-level scale what needs to be done before starting to work.

Are you going to work on this item?

@jyotisahu9 jyotisahu9 changed the title Persist task id in ACT_HI_VARINST and ACT_RU_VARIABLE tables for task variables Persist task id in ACT_HI_VARINST table for task variables Sep 23, 2024
@jyotisahu9
Copy link
Contributor Author

jyotisahu9 commented Sep 25, 2024

Hi @psavidis

Yes, I will be working on this task.

I would be making the changes to persist taskId in ACT_HI_VARINST table for following two kind of variables:
1. Task Input variables
2. Task Listener variables

Whenever a task element executes( be it through process instance or standalone task), following steps takes place:

  1. createHistoricVariableEvent - Task input variables are created
  2. createActivityInstanceStartEvt
  3. createTaskInstanceCreateEvt
  4. createActivityInstanceUpdateEvt
  5. createTaskInstanceUpdateEvt - Task listener variables are created

I would be plugging in code to set taskId for HistoricVariableInstanceEntity at below steps:

  1. createHistoricVariableEvent - Task input variables are created, but taskId is not generated.
  2. createActivityInstanceStartEvt
  3. createTaskInstanceCreateEvt - Task Id is created at this step
  4. createActivityInstanceUpdateEvt - As all the HistoricVariableInstanceEntities created in step1 are in cache at this point, retrieve them from cache, update taskId for all HistoricVariableInstanceEntities whose activityInstanceId matches with current execution activityInstanceId of task.
  5. createTaskInstanceUpdateEvt - Task listener variables are created, task id is already created at this point so set the task id for HistoricVariableInstanceEntity.

API to start task are:

  1. Through process instance is : /process-definition/key/{key}/start
  2. As a Standalone task : /task/create

API to retrieve task historic variables where taskId will be returned as response parameter are:
Get Variable Instances : /history/variable-instance
Get Variable Instance : /history/variable-instance/{id}

@jyotisahu9
Copy link
Contributor Author

jyotisahu9 commented Oct 8, 2024

Hi @psavidis,

Request you to go through details. Also this is more of bug than feature, I initially created it as feature but then could not change the category.

I have my PR ready that can be pushed to understand the whole implementation.

Thanks,
Jyoti

@jyotisahu9
Copy link
Contributor Author

Hi @psavidis ,

Could you go over the pull request and issue description when you get a chance.

Thanks,
Jyoti

@psavidis
Copy link
Contributor

psavidis commented Nov 5, 2024

Hello @jyotisahu9 ,
Apologies for the late response, it's been quite busy lately.

I'll try to find some time during this week and review the ticket and PR properly.

Till then, a question: Why do you think its a bug?

Best,
Petros

@jyotisahu9
Copy link
Contributor Author

Hi @psavidis,

Thanks for your response.

I think its a bug because there is TASK_ID_ column in ACT_HI_VARINST table but it remains null for task variable. This table saves all variable information and shall persist task id to identify specific task variable

Best,
Jyoti

@psavidis
Copy link
Contributor

psavidis commented Nov 15, 2024

Hello @jyotisahu9 ,

I had a look at the feature request and your pull request and i'd like to share with you my scepticism and questions.

So far, i'm not entirely sure what is the intent of this feature request.
You outlined in a elaborate way what you're going to change but didn't specify why.

It seems to me from the pull request of your contribution there is some confusion about the concept of variables and taskId.

Observation

I've executed the testTaskIdInHistoricVariableInstance (ref) from the PR and the test passes on master.

  • The test should fail if it would cover a missing behaviour (the taskId is not set) but it doesn't fail. Instead it passes succesfully.
  • Can you point me to a test that passes in your branch and fails on master and use that as a reference to explain what's the behaviour you'd like to achieve?

Documentation

If you read the official documentation around process variables, you'll notice the variables can have different scope executions.
Some of these executions concern process-instances and others are related to tasks.

Using that as a reference, i'd like to understand better:

a) What is the problem you'd like to solve
b) Why is that a problem

Best,
Petros

@psavidis
Copy link
Contributor

This thread does not have a response for over a month now on clarifying the feature requirements.
Closing the ticket.

@camunda camunda deleted a comment from github-actions bot Dec 19, 2024
@jyotisahu9
Copy link
Contributor Author

Hi @psavidis ,

Apologies for the delay. I was on vacation, so wasn't able to respond timely.
I will be responding soon.

Thanks,
Jyoti

@jyotisahu9
Copy link
Contributor Author

jyotisahu9 commented Dec 30, 2024

Hello @jyotisahu9 ,

I had a look at the feature request and your pull request and i'd like to share with you my scepticism and questions.

So far, i'm not entirely sure what is the intent of this feature request. You outlined in a elaborate way what you're going to change but didn't specify why.

It seems to me from the pull request of your contribution there is some confusion about the concept of variables and taskId.

Observation

I've executed the testTaskIdInHistoricVariableInstance (ref) from the PR and the test passes on master.

  • The test should fail if it would cover a missing behaviour (the taskId is not set) but it doesn't fail. Instead it passes succesfully.
  • Can you point me to a test that passes in your branch and fails on master and use that as a reference to explain what's the behaviour you'd like to achieve?

None of the test case fail in master branch. I am adding new feature, hence I added additional test cases to cover those.

Documentation

If you read the official documentation around process variables, you'll notice the variables can have different scope executions. Some of these executions concern process-instances and others are related to tasks.

Yes I have gone through scope of variables and I am not changing the scope of task or process variables through my code changes.

Using that as a reference, i'd like to understand better:

a) What is the problem you'd like to solve b) Why is that a problem

I am trying to save task id for task variables (task input variable or task execution variable) in ACT_HI_VARINST table, so that variables specific to task id can be identified. The two api's mentioned below will be then returning the saved task id as response parameter. Table act_hi_detail does save some more details about variables but this table has lot many other entries than variables. Also api's to Get Variable Instances from history table : /history/variable-instance & /history/variable-instance/{id} returns the data as per ACT_HI_VARINST table.

The main goal for this feature request is to save task id in ACT_HI_VARINST table to identify task variables and return them as part of history variable instance api. We would also be using ACT_HI_VARINST table to generate report for all the variables associated with specific task through queries.

Best, Petros

Hi @psavidis

Appreciate your detailed response & patience.

I have tried my best to explain the review comments. Let me know if you have further questions.

Thanks,
Jyoti

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type:feature Issues that add a new user feature to the project.
Projects
None yet
Development

No branches or pull requests

2 participants