Select to view content in your preferred language

Branch version Reconcile & Post Error

389
2
09-06-2022 05:57 AM
sirishb
New Contributor III

Hi All,

We are using

ArcGIS enterprise version: 10.9.1

ArcGIS Pro: V 3.0

Database: Postgres

We have enabled 'Branch version' on the feature dataset and published as "Feature services".

We are able to 'reconcile & post' using  GP Tool in ArcGIS Pro.

By using the following ArcGIS API for Python code we are trying to automate the 'reconcile & post'.

 

# Name:        Branch Version Reconcile & Post using the ArcGIS Python API

##----------------- Modules -------------------------------------------------------------
# import modules
import arcpy, datetime, requests, os
import arcgis.features
from arcgis.gis import GIS
import Config
# Disable warnings
requests.packages.urllib3.disable_warnings()
##----------------------------- Input & Derived Parameters ----------------------------------------
fs_url = arcpy.GetParameter(0)
version_name_txt = arcpy.GetParameter(1)
if fs_url.endswith("FeatureServer"):
    base_url = os.path.dirname(fs_url)
else:
    base_url = os.path.dirname(os.path.dirname(fs_url))
#--------------------------------------------------------------------------------------------------
try:
    start_time = datetime.datetime.now()
    # Service URLs and GIS object
    arcpy.AddMessage(f"connecting to {Config.portal_params.portal_url}...")
    portal = GIS(
        url=Config.portal_params.portal_url,
        password=Config.portal_params.p_password,
        username=Config.portal_params.p_username,
    )
    # Create a dict of service urls
    services = ["FeatureServer", "VersionManagementServer"]
    service_urls = {url: base_url + '/' + url for url in services}
    # The Feature Server (service URL)
    version_mgmt_svc = service_urls["VersionManagementServer"]
    vms = arcgis.features._version.VersionManager(service_urls["VersionManagementServer"], portal)
    arcpy.AddMessage(f'Version Management Service: {vms}')
    # Check if the new version exists and get the fully qualified version name from the version's properties ('owner.versionName')
    _version = [x for x in vms.all if version_name_txt in x.properties.versionName]
    fq_version_name = _version[0].properties.versionName
    arcpy.AddMessage(f'Fully qualified version name: {fq_version_name}')
   
    # Reconcile the version with Default
    with vms.get(fq_version_name, "edit") as version:  # use "edit" to run start_editing
        # Reconcile the version. Post if there are no conflicts detected.
        try:
            arcpy.AddMessage(f"Reconciling...")
            reconcile_res = version.reconcile(end_with_conflict=True, with_post=True)
            arcpy.AddMessage(f"Results of Reconcile & Post: {reconcile_res}")
            if not reconcile_res:
                arcpy.AddMessage(f"Reconciling the version {version.properties.versionName} failed.")
                raise Exception(f"Reconciling the version {version.properties.versionName} failed.")
                out_code = 1
            arcpy.AddMessage(f"Reconciled and posted version: {version.properties.versionName}")
            arcpy.AddMessage(f"Output Code: {reconcile_res}")
            out_code = 0
            arcpy.SetParameter(2, out_code)
            arcpy.AddMessage(out_code)
            end_time = datetime.datetime.now()
            elapsed_time = end_time - start_time
            arcpy.AddMessage(f"Dataset was locked for {elapsed_time.total_seconds()} secs")
        except Exception as ex:
            arcpy.AddMessage(f'Exception : {str(ex)}')
            out_code = 1
except Exception as ex:
    arcpy.AddMessage(str(ex))
    out_code = 1

 

When we execute this in ArcGIS Pro, we are getting error as "Version already in edit mode. Only one user can be editing a branch version."

Appreciate help on this please.

Thanks,

Sirish

0 Kudos
2 Replies
RJankowski
New Contributor

Hi Sirish, 

Have you ever found a solution for this problem or found out what caused it?? I have the same problem. 

Thanks, Rick

0 Kudos
sirishb
New Contributor III

Hi Rick,

Before reconcile, we implemented additional logic, if the version is locked we did 'purgeLock'. After this implementation we didn't get any error.

Thanks,

Sirish

0 Kudos