[ 
https://issues.apache.org/jira/browse/AVRO-2883?focusedWorklogId=744777&page=com.atlassian.jira.plugin.system.issuetabpanels:worklog-tabpanel#worklog-744777
 ]

ASF GitHub Bot logged work on AVRO-2883:
----------------------------------------

                Author: ASF GitHub Bot
            Created on: 20/Mar/22 20:54
            Start Date: 20/Mar/22 20:54
    Worklog Time Spent: 10m 
      Work Description: zcsizmadia commented on a change in pull request #1610:
URL: https://github.com/apache/avro/pull/1610#discussion_r830671739



##########
File path: lang/csharp/src/apache/codegen/AvroGen.cs
##########
@@ -193,5 +194,49 @@ static void Usage()
 
             return 0;
         }
+
+        /// <summary>
+        /// Replace namespace(s) in schema or protocol definition.
+        /// </summary>
+        /// <param name="input">input schema or protocol definition.</param>
+        /// <param name="namespaceMapping">namespace mappings object.</param>
+        public static string ReplaceMappedNamespacesInSchema(string input, 
IEnumerable<KeyValuePair<string, string>> namespaceMapping)

Review comment:
       Not really. I think my original intention was to add unit test to test 
specifically the replace code. However I decided not to, since there is "high" 
level tests, which indirectly test this function. I will go ahead and make it 
private.




-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


Issue Time Tracking
-------------------

    Worklog Id:     (was: 744777)
    Time Spent: 1h  (was: 50m)

> Avrogen (csharp) namespace mapping missing for references
> ---------------------------------------------------------
>
>                 Key: AVRO-2883
>                 URL: https://issues.apache.org/jira/browse/AVRO-2883
>             Project: Apache Avro
>          Issue Type: Bug
>          Components: csharp
>            Reporter: Thomas Vigh Sørensen
>            Assignee: Zoltan Csizmadia
>            Priority: Major
>              Labels: pull-request-available
>          Time Spent: 1h
>  Remaining Estimate: 0h
>
> When using *avrogen* for generating C# models from a schemafile, the 
> *--namespace* option doesn't behave as expected, if the model refers to other 
> types (currently only tested with enums). 
> When running 
> {code:java}
> avrogen -s file.avsc . --namespace my.avro.ns:my.csharp.ns
> {code}
> the actual namespace of the generated C# files is changed to *my.csharp.ns*, 
> but any references between the models are not updated with the correct 
> namespace.
>  
> Given a schemafile containing:
> {code:json}
> {
>   "type" : "record",
>   "name" : "TestModel",
>   "namespace" : "my.avro.ns",
>   "fields" : [ {
>     "name" : "eventType",
>     "type" : {
>       "type" : "enum",
>       "name" : "EventType",
>       "symbols" : [ "CREATE", "UPDATE", "DELETE" ]
>     }
>   } ]
> }
> {code}
> And running 
> {code:java}
> avrogen -s models.avsc . --namespace my.avro.ns:my.csharp.ns
> {code}
>  
> Will produce the following *EventType.cs*
> {code:c#}
> namespace my.csharp.ns
> {
>       using System;
>       using System.Collections.Generic;
>       using System.Text;
>       using Avro;
>       using Avro.Specific;
>       
>       public enum EventType
>       {
>               CREATE,
>               UPDATE,
>               DELETE,
>       }
> }
> {code}
>  
> and the following *TestModel.cs*
> {code:c#}
> namespace my.csharp.ns
> {
>       using System;
>       using System.Collections.Generic;
>       using System.Text;
>       using Avro;
>       using Avro.Specific;
>       
>       public partial class TestModel : ISpecificRecord
>       {
>               public static Schema _SCHEMA = 
> Avro.Schema.Parse("{\"type\":\"record\",\"name\":\"TestModel\",\"namespace\":\"my.avro.ns\",\"fields\":[{\"name\":\"e"
>  +
>                               
> "ventType\",\"type\":{\"type\":\"enum\",\"name\":\"EventType\",\"namespace\":\"my.avro.ns\",\"sym"
>  +
>                               
> "bols\":[\"CREATE\",\"UPDATE\",\"DELETE\"]}}]}");
>               private my.avro.ns.EventType _eventType;
>                // More generated code
>         }
> }
> {code}
> Notice how the namespace is set correctly to *my.csharp.ns* in both files, 
> but the namespace of the referenced *EventType* in *TestModel.cs* is 
> incorrect.
>  
> Example of expected output (*TestModel.cs*):
> {code:c#}
> namespace my.csharp.ns
> {
>       using System;
>       using System.Collections.Generic;
>       using System.Text;
>       using Avro;
>       using Avro.Specific;
>       
>       public partial class TestModel : ISpecificRecord
>       {
>               public static Schema _SCHEMA = 
> Avro.Schema.Parse("{\"type\":\"record\",\"name\":\"TestModel\",\"namespace\":\"my.avro.ns\",\"fields\":[{\"name\":\"e"
>  +
>                               
> "ventType\",\"type\":{\"type\":\"enum\",\"name\":\"EventType\",\"namespace\":\"my.avro.ns\",\"sym"
>  +
>                               
> "bols\":[\"CREATE\",\"UPDATE\",\"DELETE\"]}}]}");
>               private my.csharp.ns.EventType _eventType;
>                // More generated code
>         }
> }
> {code}
>  
> Code for reproducing the issue can be found at: 
> [https://github.com/FuKe/avrogen-namespace-bug]



--
This message was sent by Atlassian Jira
(v8.20.1#820001)

Reply via email to