-
-
Notifications
You must be signed in to change notification settings - Fork 45
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
[17.0] [MIG] connector_jira: Migration to 17.0 #107
Open
nedaszilinskas
wants to merge
81
commits into
OCA:17.0
Choose a base branch
from
nedaszilinskas:17.0-mig-connector_jira
base: 17.0
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add project binding Add export of projects Add Jira project tasks model Add external dependencies in manifest Add security accesses Add basic import of tasks Task import are triggered by Jira webhooks. A batch import must be added later to import the changes from missed hooks or for those not wanting to use the webhooks. Add a basic backend adapter Batch import of project tasks Remove markdown The fields are not in markdown, but in a wiki syntax (proper to JIRA yet be determined) Link users and import tasks assignees Import worklogs Use an adapter for the project export Import issue types Filter type of issues to synchronize And assign the worklog to the first parent we find that we synchronize. If the type of the worklog's issue is synchronized, the worklog is assigned on this issue. If the worklog's issue is a sub-task, and the parent task of the sub-task is of a synchronized type, it link it to it. If the task has an epic, and the epics are synchronized, it link it to it. In last resort, the worklog will be linked with the project but with no task. Configure the name of the Epic Link field from API Create webhooks in JIRA from Odoo Choose template on project creation Discard Epics from different projects JIRA allow to choose an epic for any project. Setting the Epic as the Odoo task would create inconsistencies between the project and the task. We discard such an Epic, likely the task will be empty. Delete worklogs deleted on JIRA (only with webhooks) Delete tasks deleted on JIRA (only with webhooks) Add JIRA issue type in tasks Add JIRA Issue Key Add core business project types Improve display of JIRA backend Use a dedicated button to activate the Epic Link. Link the Epic in a dedicated field Add JIRA Parent for subtasks Show JIRA key in name Create project from shared project Check JIRA project keys Remove the button to 'one-click-export' a project It can't be working because we have other fields to configure on the binding. Add help on issue type synchronizations Accept tasks without parent Do not use id builtin
add `jira_account_analytic_line` object
Replace openerp namespace by odoo namespace Change to new Binder's API Migrate connector_jira to new 10.0 API Make addons uninstallable Apply 2to3 for python3 Migrate to new Component API Add setup guide in readme Migrate to v11 and Py3 Allow to delete a backend if we have issue types
Fix project listener name typo Add links to JIRA issue on a.a.l Fix connector tab naming
text_field as attribute could not by validated by RNG, options is always valid Add base to support both export and link with projects Now linking a project with JIRA must be done through a wizard instead of the binding view. It must be either export (create the project on jira) or link (link with an existing project on jira). We keep this choice in the binding so we never export data to JIRA when we chose the link only.
Map projects by external_id + set of jira orgs Project bindings now can be assigned to one or more jira organizations. The binding for the project accept an additional argument for organizations. A task will be linked with the project having the exact same set of organizations that it has, or fallback to a project without organization. A constraint ensures that you cannot have several projects with the same set of organizations or 2 projects without organization. The link wizard has a new step to select the organization. The REST API for Serviced Desk is a different one. The former code was based on pycontribs/jira#388 which is closed and unmaintained. We only need to read the organizations from the servicedesk REST API and the local code is minimal. We can now use the normal jira library.
A normal user must be able to use the jira rest client under the hood. Update documentation Store original jira issues on analytic lines Instead of the issue they are linked to in Odoo. With the mechanism in place, if we don't import the task or bug issue types and we synchronize the epics, the worklogs will be attached to the epics of their tasks (of subtasks to tasks). The fields were showing the values of the Epic (or task for subtask), though it makes much more sense to keep the keys and URLs of the original issue and epic on the analytic lines. We still have the link to the task if we want to get the URL for the task they are currently linked to. Fix project binding unique constraint We should be able to have 2 bindings without external_id (not yet exported) Add wizard to link a task to JIRA Refactorize multistep wizards with a mixin Handle jira bindings in tasks merge wizard Import name of Epics instead of summary The Epic issues have a special (custom) field for their name. In fact they use both, the custom field AND the summary field. But I guess they are better identified by their epic name than their summary. Extract multi_step_wizard as an addon Set a timeout on requests to JIRA Fix typo in readme Fix backend selection on wizard to link a task The computed field was not called, due to the model being a TransientModel, replace it by default values. Add is_master on jira project bindings Allow to have one project binding per project type The unicity constraint (backend_id, odoo_id) on jira.backend.backend is relaxed: it now allows one binding of each type. The reason for this is: * supporting several projects of different types is a requirements (eg. 1 service desk and 1 software) * but if we implement new features like "if I create a task it is pushed to Jira", with different projects we would not know where to push them Using this constraint, we'll be able to focus new export features by project type. Move jira_key from project to jira project binding As we can have more than one project binding, we cannot store a single jira key. In case we have more than one jira key for a project, we compute a compound key joined by commas. Add method to handle jira API / connection errors Add migration for 11.0.1.1.0 Fix error when several odoo users match When we are importing a worklog for a user not yet linked and we found several candidate users in odoo, they will both be linked with the same jira user and make the unicity constraint fail. Properly raise an error in this case. Fix project_type as string Add fallback project for worklogs A new optional field on the backend allows to choose a fallback project for the worklogs. When a worklog doesn't match any project linked with Jira, they will be created there, allowing to find the misconfigurations and fix them. Add action to reimport worklogs from Jira This is meant mainly to be used when a worklog has been imported in the fallback project and we need to re-affect them to the correct project after we linked it. Add related action to open jira with import issues The 'related' button on jobs which import issues or worklog will now open jira directly on the issue. Skip import of tasks/worklogs before batch dates Jira may send webhooks for old records, for instance worklogs from 6 month ago because their task has been changed. This change ensures that we never import any record which has a last update date before the last date of batch import. The job methods now return the result of Importer.run() so the result is shown on the jobs in the UI. Extract import of dependencies Allowing to override partially the dependencies to import Fix import of subtasks When importing the parent of a subtask, the record in the 'parent' field (the task data) is incomplete, it contains only a few fields. Providing only the id to the dependency Importer will force it to read the whole record from Jira. Prevent duplicates with inactive projects The constraint did not look for inactive projects, which makes the import fail later because it finds several projects for the same task. Handle 404 errors when importing records When a record does not exist on Jira: * the job is done instead of failed * a result on the job tells about the missing record * the binding is deleted on Odoo * for worklogs, the analytic line is deleted as well Change xmlid for model_account_analytic_line account is not necessarily installed, while analytic is installed by the project module in any case Partial revert of 2fa7d39 Commit title was: Skip import of tasks/worklogs before batch dates The process is the following: * Read T from backend, T is the is the last time we ran the import * Create a batch job to import tasks/worklogs from T to now() and update the backend with now() The batch job is run asynchronously, it generates one job per task or worklog to import between T and now(). When the jobs are executed, the last batch date has already been updated to now(), so the jobs would never import any record. Fix error when force_reimport called on several records Prevent changing task's project on binding When the task Mapper binds a task to a task already existing in Odoo, we must not change the project_id of the task. This is not possible as long as we have invoiced timesheet lines, even if the id is the same than the current one. Add base for tests and a test for oauth Add test for check of connection With a fix in the method: getting the client only wasn't triggering any error, calling 'myself' raises a 401 when we are not authenticated. Add documentation for tests Add travis configuration Add tests on issue types and tasks Add first test for analytic account lines Make pylint-odoo happy Add a script to initiate the Oauth dance
Co-Authored-By: guewen <[email protected]>
When another user is already linked with the same jira user and matches. Without this check, the transaction fails with a unique constraint error. Do not change project_id on tasks updates When a task has invoiced timesheet lines, writing on 'project_id', even if the id is the same, would fail because of a constraint preventing to write project_id on timesheet lines. Refactorize aal batch importer with 'updating since' jira method This Jira method returns the list of ids updated since a timestamp, and the youngest timestamp, which means we can store this timestamp and reuse it the next time we ask the modified worklogs: this way we should never miss any update. To support this, a type of field which support milliseconds in datetime is required, otherwise lose this precision that Jira gives us. As of today, the "updated since" method exists on for worklogs on the Jira webservice, so the rest of the batch import still have to use the JQL filters (with minute-precision only). Use Datetime as main format for MilliDatetime field Store jira's 'updated_at' field to compare with binding We can compare the millisecond dates on both sides to see if any changes has been done on Jira and avoid useless writes. Previously, we were using the 'sync_date' field, which works too but will make more sync than necessary (because the sync happens after the last jira's updated_at value). Fortuitously, the updated_at is also very useful for debugging purposes. Add batch deleter for worklogs Force reimport of worklogs as admin Add tests for jira.backend.timestamp Add jira.backend tests Fix JiraTransactionCase → JiraSavepointCase 👀 Add tests for batch importer of tasks and worklogs Add tests for worklogs deletes Fix lint
Co-Authored-By: guewen <[email protected]>
Apply suggestions from @simahawk in code review Add scheduled action for importing deleted worklogs Fix fetch pagination of organizations The pagination specs of the servicedesk API are not the same than the Jira API (respectively isLastPage vs lastPage). So the lib's _fetch_pages does not fetch all the pages. Optimize the requests: we get all the data at the initial call, so the records are passed directly to "import_record" which will not do another request.
It seems that when updating other addons, even if we don't update connector_jira, it may already create the columns, then when we update connector_jira, it tries to create the columns when they already exist. Check before. Use the rendered task description as HTML The Jira REST API returns a rendered version of the description instead of the markup when we pass the 'expand=renderedFields' parameter. Update vrcpy cassettes as we read expanded issues With "expand=renderedFields"
Imported task on inactive project set task inactive too
Make epic field lookup fault tolerant Tempo: sync status, add tests
Read the new design notes section in the readme for details.
- specify key/value when user binding fails - resolve by login (which is unique) first, then my potentially-conflicting email - if multiple JIRA users are returned, merge them by key as it's unique
nedaszilinskas
force-pushed
the
17.0-mig-connector_jira
branch
4 times, most recently
from
May 27, 2024 05:23
33e6e3d
to
90fb98b
Compare
nedaszilinskas
changed the title
[MIG] connector_jira: Migration to 17.0
[WIP] [MIG] connector_jira: Migration to 17.0
May 27, 2024
nedaszilinskas
force-pushed
the
17.0-mig-connector_jira
branch
2 times, most recently
from
May 31, 2024 11:14
2fa9b54
to
198f121
Compare
nedaszilinskas
force-pushed
the
17.0-mig-connector_jira
branch
from
June 12, 2024 17:08
198f121
to
a3a6962
Compare
nedaszilinskas
changed the title
[WIP] [MIG] connector_jira: Migration to 17.0
[17.0] [MIG] connector_jira: Migration to 17.0
Jun 19, 2024
Help with running tests would be much appreciated |
nedaszilinskas
force-pushed
the
17.0-mig-connector_jira
branch
from
July 2, 2024 08:25
a3a6962
to
362268f
Compare
Hi @nedaszilinskas |
nedaszilinskas
force-pushed
the
17.0-mig-connector_jira
branch
from
November 20, 2024 10:48
e2d25a0
to
bfe2f8a
Compare
nedaszilinskas
force-pushed
the
17.0-mig-connector_jira
branch
from
November 20, 2024 10:48
bfe2f8a
to
0216962
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
No description provided.