Skip to content

Commit 23be46f

Browse files
authored
Fix using StringEnumConverter with naming strategy and specifie… (#2186)
1 parent ff6f51b commit 23be46f

File tree

2 files changed

+83
-3
lines changed

2 files changed

+83
-3
lines changed
Lines changed: 76 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
#region License
2+
// Copyright (c) 2007 James Newton-King
3+
//
4+
// Permission is hereby granted, free of charge, to any person
5+
// obtaining a copy of this software and associated documentation
6+
// files (the "Software"), to deal in the Software without
7+
// restriction, including without limitation the rights to use,
8+
// copy, modify, merge, publish, distribute, sublicense, and/or sell
9+
// copies of the Software, and to permit persons to whom the
10+
// Software is furnished to do so, subject to the following
11+
// conditions:
12+
//
13+
// The above copyright notice and this permission notice shall be
14+
// included in all copies or substantial portions of the Software.
15+
//
16+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17+
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
18+
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
19+
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
20+
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
21+
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
22+
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
23+
// OTHER DEALINGS IN THE SOFTWARE.
24+
#endregion
25+
26+
#if !NET20
27+
using System;
28+
using System.Collections;
29+
using System.Collections.Generic;
30+
using System.Runtime.Serialization;
31+
using Newtonsoft.Json.Converters;
32+
using Newtonsoft.Json.Serialization;
33+
#if DNXCORE50
34+
using Xunit;
35+
using Test = Xunit.FactAttribute;
36+
using Assert = Newtonsoft.Json.Tests.XUnitAssert;
37+
#else
38+
using NUnit.Framework;
39+
#endif
40+
41+
namespace Newtonsoft.Json.Tests.Issues
42+
{
43+
[TestFixture]
44+
public class Issue2082
45+
{
46+
[Test]
47+
public void Test()
48+
{
49+
CamelCaseNamingStrategy namingStrategy = new CamelCaseNamingStrategy(processDictionaryKeys: true, overrideSpecifiedNames: false);
50+
51+
TestClass c = new TestClass { Value = TestEnum.UpperCaseName };
52+
string json = JsonConvert.SerializeObject(c, new JsonSerializerSettings
53+
{
54+
ContractResolver = new DefaultContractResolver
55+
{
56+
NamingStrategy = namingStrategy
57+
},
58+
Converters = new[] { new StringEnumConverter { NamingStrategy = namingStrategy } }
59+
});
60+
61+
Assert.AreEqual(@"{""value"":""UPPER_CASE_NAME""}", json);
62+
}
63+
64+
public class TestClass
65+
{
66+
public TestEnum Value { get; set; }
67+
}
68+
69+
public enum TestEnum
70+
{
71+
[EnumMember(Value = "UPPER_CASE_NAME")]
72+
UpperCaseName
73+
}
74+
}
75+
}
76+
#endif

Src/Newtonsoft.Json/Utilities/EnumUtils.cs

Lines changed: 7 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,7 @@ private static EnumInfo InitializeValuesAndNames(StructMultiKey<Type, NamingStra
5454
string[] names = Enum.GetNames(enumType);
5555
string[] resolvedNames = new string[names.Length];
5656
ulong[] values = new ulong[names.Length];
57+
bool hasSpecifiedName;
5758

5859
for (int i = 0; i < names.Length; i++)
5960
{
@@ -63,21 +64,24 @@ private static EnumInfo InitializeValuesAndNames(StructMultiKey<Type, NamingStra
6364

6465
string resolvedName;
6566
#if HAVE_DATA_CONTRACTS
66-
resolvedName = f.GetCustomAttributes(typeof(EnumMemberAttribute), true)
67+
string specifiedName = f.GetCustomAttributes(typeof(EnumMemberAttribute), true)
6768
.Cast<EnumMemberAttribute>()
6869
.Select(a => a.Value)
69-
.SingleOrDefault() ?? f.Name;
70+
.SingleOrDefault();
71+
hasSpecifiedName = specifiedName != null;
72+
resolvedName = specifiedName ?? name;
7073

7174
if (Array.IndexOf(resolvedNames, resolvedName, 0, i) != -1)
7275
{
7376
throw new InvalidOperationException("Enum name '{0}' already exists on enum '{1}'.".FormatWith(CultureInfo.InvariantCulture, resolvedName, enumType.Name));
7477
}
7578
#else
7679
resolvedName = name;
80+
hasSpecifiedName = false;
7781
#endif
7882

7983
resolvedNames[i] = key.Value2 != null
80-
? key.Value2.GetPropertyName(resolvedName, false)
84+
? key.Value2.GetPropertyName(resolvedName, hasSpecifiedName)
8185
: resolvedName;
8286
}
8387

0 commit comments

Comments
 (0)