Fix DefaultHeaders.toString() for keys with multiple values.

Motivation:

For example,

DefaultHttp2Headers headers = new DefaultHttp2Headers();
headers.add("key1", "value1");
headers.add("key1", "value2");
headers.add("key1", "value3");
headers.add("key2", "value4");

produces:

DefaultHttp2Headers[key1: value1key1: value2key1: value3, key2: value4]

while correctly it should be

DefaultHttp2Headers[key1: value1, key1: value2, key1: value3, key2: value4]

Modifications:

Change the toString() method to produce the beforementioned output.

Result:

toString() format is correct also for keys with multiple values.
This commit is contained in:
buchgr 2016-06-02 15:41:37 +02:00 committed by Norman Maurer
parent e200e4811b
commit af7b0a04a0
2 changed files with 23 additions and 1 deletions

View File

@ -899,9 +899,9 @@ public class DefaultHeaders<K, V, T extends Headers<K, V, T>> implements Headers
for (int i = 0; i < values.size(); ++i) {
builder.append(separator);
builder.append(name).append(": ").append(values.get(i));
}
separator = ", ";
}
}
return builder.append(']').toString();
}

View File

@ -450,4 +450,26 @@ public class DefaultHeadersTest {
headers.set(headers);
assertEquals(1, headers.size());
}
@Test
public void testToString() {
TestDefaultHeaders headers = newInstance();
headers.add(of("name1"), of("value1"));
headers.add(of("name1"), of("value2"));
headers.add(of("name2"), of("value3"));
assertEquals("TestDefaultHeaders[name1: value1, name1: value2, name2: value3]", headers.toString());
headers = newInstance();
headers.add(of("name1"), of("value1"));
headers.add(of("name2"), of("value2"));
headers.add(of("name3"), of("value3"));
assertEquals("TestDefaultHeaders[name1: value1, name2: value2, name3: value3]", headers.toString());
headers = newInstance();
headers.add(of("name1"), of("value1"));
assertEquals("TestDefaultHeaders[name1: value1]", headers.toString());
headers = newInstance();
assertEquals("TestDefaultHeaders[]", headers.toString());
}
}