[ 
https://issues.apache.org/jira/browse/ATLAS-5321?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Brijesh Bhalala updated ATLAS-5321:
-----------------------------------
    Summary: Backend: Basic Search for term throws ATLAS-400-00-06E 
"Unknown/invalid glossary term" after updating parent Glossary  (was: Backend: 
Basic Search throws ATLAS-400-00-06E "Unknown/invalid glossary term" after 
updating parent Glossary)

> Backend: Basic Search for term throws ATLAS-400-00-06E "Unknown/invalid 
> glossary term" after updating parent Glossary
> ---------------------------------------------------------------------------------------------------------------------
>
>                 Key: ATLAS-5321
>                 URL: https://issues.apache.org/jira/browse/ATLAS-5321
>             Project: Atlas
>          Issue Type: Bug
>          Components:  atlas-core
>    Affects Versions: 2.5.0
>            Reporter: Brijesh Bhalala
>            Assignee: Aditya Gupta
>            Priority: Minor
>              Labels: backend
>
> *Issue Overview:* A basic search for a valid Glossary Term using the 
> {{termName}} parameter fails with an {{ATLAS-400-00-06E}} error if its parent 
> Glossary has been recently updated. The term search works perfectly 
> immediately after creation but breaks as soon as the associated Glossary 
> undergoes any update operation.
> *Steps to Reproduce:*
>  # Create a new Glossary (e.g., {{{}gloss23{}}}).
>  # Create a new Term within this glossary (e.g., {{{}term2{}}}, with 
> qualifiedName {{{}term2@gloss23{}}}).
>  # Perform a Basic Search via the API ({{{}/api/atlas/v2/search/basic{}}}) 
> passing the term in the payload:
> json
>  
> {
> "termName": "term2@gloss23"
> }
>  # Verify the search completes successfully and returns the expected results.
>  # Update the parent Glossary ({{{}gloss23{}}}) via the UI or API (e.g., 
> change its description or add an attribute).
>  # Perform the exact same Basic Search from Step 3 again.
> *Expected Behavior:* The Basic Search API should successfully execute and 
> return the term/entities without any errors, identical to the behavior before 
> the glossary was updated.
> *Actual Behavior:* The API throws a 400 Bad Request error, claiming the term 
> no longer exists:
>  
> json
>  
> {
> "errorCode": "ATLAS-400-00-06E",
> "errorMessage": "term2@gloss23: Unknown/invalid glossary term"
> }
> *Potential Root Causes (Backend):*
>  * *Search Index/Cache Invalidation:* Updating the parent Glossary might be 
> inadvertently dropping or corrupting the JanusGraph index / Solr cache for 
> its child terms.
>  * *Graph Edge Modification:* The glossary update process might be 
> incorrectly modifying or recreating the {{AtlasGlossaryTerm}} edges, causing 
> the Basic Search validator to fail when looking up the term's 
> {{{}qualifiedName{}}}.
>  * *Term Status Disconnect:* The search validator may be referencing a stale 
> state of the Glossary that fails to correctly resolve active child terms 
> after a save operation.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to