fixes OLINGO-227
This commit is contained in:
parent
9806a2737c
commit
b275fc40e9
12
fit/pom.xml
12
fit/pom.xml
|
@ -94,18 +94,6 @@
|
||||||
<defaultGoal>clean package cargo:run</defaultGoal>
|
<defaultGoal>clean package cargo:run</defaultGoal>
|
||||||
|
|
||||||
<plugins>
|
<plugins>
|
||||||
<plugin>
|
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
|
||||||
<artifactId>maven-resources-plugin</artifactId>
|
|
||||||
<version>2.6</version>
|
|
||||||
<configuration>
|
|
||||||
<useDefaultDelimiters>false</useDefaultDelimiters>
|
|
||||||
<delimiters>
|
|
||||||
<delimiter>${*}</delimiter>
|
|
||||||
</delimiters>
|
|
||||||
</configuration>
|
|
||||||
</plugin>
|
|
||||||
|
|
||||||
<plugin>
|
<plugin>
|
||||||
<groupId>org.apache.maven.plugins</groupId>
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
<artifactId>maven-war-plugin</artifactId>
|
<artifactId>maven-war-plugin</artifactId>
|
||||||
|
|
|
@ -1017,15 +1017,17 @@ public abstract class AbstractServices {
|
||||||
|
|
||||||
final String basePath = Commons.getEntityBasePath(entitySetName, entityId);
|
final String basePath = Commons.getEntityBasePath(entitySetName, entityId);
|
||||||
|
|
||||||
InputStream stream = FSManager.instance(getVersion()).readFile(
|
|
||||||
basePath + Constants.get(getVersion(), ConstantKey.ENTITY), acceptType == null || acceptType == Accept.TEXT
|
|
||||||
? Accept.XML : acceptType);
|
|
||||||
|
|
||||||
final AbstractUtilities utils = getUtilities(acceptType);
|
final AbstractUtilities utils = getUtilities(acceptType);
|
||||||
|
|
||||||
final List<String> pathElements = Arrays.asList(path.split("\\/"));
|
final List<String> pathElements = Arrays.asList(path.split("\\/"));
|
||||||
|
|
||||||
|
InputStream stream;
|
||||||
|
|
||||||
if (searchForValue) {
|
if (searchForValue) {
|
||||||
|
stream = FSManager.instance(getVersion()).readFile(
|
||||||
|
basePath + Constants.get(getVersion(), ConstantKey.ENTITY),
|
||||||
|
acceptType == null || acceptType == Accept.TEXT ? Accept.XML : acceptType);
|
||||||
|
|
||||||
stream = utils.getPropertyValue(stream, pathElements);
|
stream = utils.getPropertyValue(stream, pathElements);
|
||||||
} else {
|
} else {
|
||||||
String edmType = xml.getEdmTypeFromAtom(entitySetName, entityId, pathElements);
|
String edmType = xml.getEdmTypeFromAtom(entitySetName, entityId, pathElements);
|
||||||
|
|
|
@ -63,7 +63,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
new TextNode(Commons.getLinksURI(version, entitySetName, entitykey, link)));
|
new TextNode(Commons.getLinksURI(version, entitySetName, entitykey, link)));
|
||||||
}
|
}
|
||||||
|
|
||||||
return IOUtils.toInputStream(srcNode.toString());
|
return IOUtils.toInputStream(srcNode.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -126,7 +126,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
|
|
||||||
links.addLinks(title, hrefs);
|
links.addLinks(title, hrefs);
|
||||||
} else if (Commons.linkInfo.get(version).exists(entitySetName, field.getKey())) {
|
} else if (Commons.linkInfo.get(version).exists(entitySetName, field.getKey())) {
|
||||||
links.addInlines(field.getKey(), IOUtils.toInputStream(field.getValue().toString()));
|
links.addInlines(field.getKey(), IOUtils.toInputStream(field.getValue().toString(), "UTf-8"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -171,7 +171,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
Constants.get(version, ConstantKey.JSON_EDITLINK_NAME), new TextNode(
|
Constants.get(version, ConstantKey.JSON_EDITLINK_NAME), new TextNode(
|
||||||
Constants.get(version, ConstantKey.DEFAULT_SERVICE_URL) + entitySetName + "(" + entityKey + ")"));
|
Constants.get(version, ConstantKey.DEFAULT_SERVICE_URL) + entitySetName + "(" + entityKey + ")"));
|
||||||
|
|
||||||
return IOUtils.toInputStream(srcNode.toString());
|
return IOUtils.toInputStream(srcNode.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -303,7 +303,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
|
|
||||||
srcNode.retain(retain);
|
srcNode.retain(retain);
|
||||||
|
|
||||||
return IOUtils.toInputStream(srcNode.toString());
|
return IOUtils.toInputStream(srcNode.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -352,7 +352,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
node.set(Constants.get(version, ConstantKey.JSON_NEXTLINK_NAME), new TextNode(next));
|
node.set(Constants.get(version, ConstantKey.JSON_NEXTLINK_NAME), new TextNode(next));
|
||||||
}
|
}
|
||||||
|
|
||||||
return IOUtils.toInputStream(node.toString());
|
return IOUtils.toInputStream(node.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -375,7 +375,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
toBeChangedNode.set(linkName + Constants.get(version, ConstantKey.JSON_NEXTLINK_SUFFIX), next);
|
toBeChangedNode.set(linkName + Constants.get(version, ConstantKey.JSON_NEXTLINK_SUFFIX), next);
|
||||||
}
|
}
|
||||||
|
|
||||||
return IOUtils.toInputStream(toBeChangedNode.toString());
|
return IOUtils.toInputStream(toBeChangedNode.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -388,7 +388,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
final Iterator<Map.Entry<String, JsonNode>> fields = srcObject.fields();
|
final Iterator<Map.Entry<String, JsonNode>> fields = srcObject.fields();
|
||||||
while (fields.hasNext()) {
|
while (fields.hasNext()) {
|
||||||
final Map.Entry<String, JsonNode> field = fields.next();
|
final Map.Entry<String, JsonNode> field = fields.next();
|
||||||
res.put(field.getKey(), IOUtils.toInputStream(field.getValue().toString()));
|
res.put(field.getKey(), IOUtils.toInputStream(field.getValue().toString(), "UTf-8"));
|
||||||
}
|
}
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
|
@ -406,7 +406,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
toBeChangedObject.set(property.getKey(), propertyNode);
|
toBeChangedObject.set(property.getKey(), propertyNode);
|
||||||
}
|
}
|
||||||
|
|
||||||
return IOUtils.toInputStream(toBeChangedObject.toString());
|
return IOUtils.toInputStream(toBeChangedObject.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -452,7 +452,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
IOUtils.closeQuietly(content);
|
IOUtils.closeQuietly(content);
|
||||||
|
|
||||||
srcNode.set(Constants.get(version, ConstantKey.JSON_EDITLINK_NAME), new TextNode(href));
|
srcNode.set(Constants.get(version, ConstantKey.JSON_EDITLINK_NAME), new TextNode(href));
|
||||||
return IOUtils.toInputStream(srcNode.toString());
|
return IOUtils.toInputStream(srcNode.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -481,7 +481,7 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
|
|
||||||
((ObjectNode) node).set(path.get(path.size() - 1), replacementNode);
|
((ObjectNode) node).set(path.get(path.size() - 1), replacementNode);
|
||||||
|
|
||||||
return IOUtils.toInputStream(srcNode.toString());
|
return IOUtils.toInputStream(srcNode.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -500,6 +500,6 @@ public abstract class AbstractJSONUtilities extends AbstractUtilities {
|
||||||
|
|
||||||
((ObjectNode) node).set(path.get(path.size() - 1), null);
|
((ObjectNode) node).set(path.get(path.size() - 1), null);
|
||||||
|
|
||||||
return IOUtils.toInputStream(srcNode.toString());
|
return IOUtils.toInputStream(srcNode.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -387,18 +387,14 @@ public abstract class AbstractUtilities {
|
||||||
builder.header("ETag", etag);
|
builder.header("ETag", etag);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (accept != null) {
|
|
||||||
builder.header("Content-Type", accept.toString(version));
|
|
||||||
} else {
|
|
||||||
builder.header("Content-Type", "*/*");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (status != null) {
|
if (status != null) {
|
||||||
builder.status(status);
|
builder.status(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
int contentLength = 0;
|
int contentLength = 0;
|
||||||
|
|
||||||
|
String contentTypeEncoding = StringUtils.EMPTY;
|
||||||
|
|
||||||
if (entity != null) {
|
if (entity != null) {
|
||||||
try {
|
try {
|
||||||
final InputStream toBeStreamedBack;
|
final InputStream toBeStreamedBack;
|
||||||
|
@ -415,12 +411,15 @@ public abstract class AbstractUtilities {
|
||||||
|
|
||||||
contentLength = bos.size();
|
contentLength = bos.size();
|
||||||
builder.entity(new ByteArrayInputStream(bos.toByteArray()));
|
builder.entity(new ByteArrayInputStream(bos.toByteArray()));
|
||||||
|
|
||||||
|
contentTypeEncoding = ";odata.streaming=true;charset=utf-8";
|
||||||
} catch (IOException ioe) {
|
} catch (IOException ioe) {
|
||||||
LOG.error("Error streaming response entity back", ioe);
|
LOG.error("Error streaming response entity back", ioe);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
builder.header("Content-Length", contentLength);
|
builder.header("Content-Length", contentLength);
|
||||||
|
builder.header("Content-Type", (accept == null ? "*/*" : accept.toString(version)) + contentTypeEncoding);
|
||||||
|
|
||||||
return builder.build();
|
return builder.build();
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,7 @@ import java.io.File;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.io.OutputStreamWriter;
|
import java.io.OutputStreamWriter;
|
||||||
import java.io.StringWriter;
|
import java.nio.charset.Charset;
|
||||||
import java.util.AbstractMap;
|
import java.util.AbstractMap;
|
||||||
import java.util.AbstractMap.SimpleEntry;
|
import java.util.AbstractMap.SimpleEntry;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -75,7 +75,7 @@ public abstract class AbstractXMLUtilities extends AbstractUtilities {
|
||||||
ifactory = XMLInputFactory.newInstance();
|
ifactory = XMLInputFactory.newInstance();
|
||||||
}
|
}
|
||||||
ifactory.setProperty(XMLInputFactory.IS_NAMESPACE_AWARE, false);
|
ifactory.setProperty(XMLInputFactory.IS_NAMESPACE_AWARE, false);
|
||||||
return ifactory.createXMLEventReader(is);
|
return ifactory.createXMLEventReader(is, "utf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static XMLEventWriter getEventWriter(final OutputStream os) throws XMLStreamException {
|
protected static XMLEventWriter getEventWriter(final OutputStream os) throws XMLStreamException {
|
||||||
|
@ -83,7 +83,7 @@ public abstract class AbstractXMLUtilities extends AbstractUtilities {
|
||||||
ofactory = XMLOutputFactory.newInstance();
|
ofactory = XMLOutputFactory.newInstance();
|
||||||
}
|
}
|
||||||
|
|
||||||
return ofactory.createXMLEventWriter(os);
|
return ofactory.createXMLEventWriter(os, "utf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void writeEvent(final XMLEvent event, final XMLEventWriter writer) {
|
private void writeEvent(final XMLEvent event, final XMLEventWriter writer) {
|
||||||
|
@ -369,7 +369,9 @@ public abstract class AbstractXMLUtilities extends AbstractUtilities {
|
||||||
final XmlElement res = new XmlElement();
|
final XmlElement res = new XmlElement();
|
||||||
res.setStart(start);
|
res.setStart(start);
|
||||||
|
|
||||||
StringWriter content = new StringWriter();
|
final Charset encoding = Charset.forName("UTF-8");
|
||||||
|
final ByteArrayOutputStream content = new ByteArrayOutputStream();
|
||||||
|
final OutputStreamWriter writer = new OutputStreamWriter(content, encoding);
|
||||||
|
|
||||||
int depth = 1;
|
int depth = 1;
|
||||||
|
|
||||||
|
@ -385,14 +387,14 @@ public abstract class AbstractXMLUtilities extends AbstractUtilities {
|
||||||
if (depth == 0) {
|
if (depth == 0) {
|
||||||
res.setEnd(event.asEndElement());
|
res.setEnd(event.asEndElement());
|
||||||
} else {
|
} else {
|
||||||
event.writeAsEncodedUnicode(content);
|
event.writeAsEncodedUnicode(writer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
content.flush();
|
writer.flush();
|
||||||
content.close();
|
writer.close();
|
||||||
|
|
||||||
res.setContent(new ByteArrayInputStream(content.toString().getBytes()));
|
res.setContent(new ByteArrayInputStream(content.toByteArray()));
|
||||||
|
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -851,24 +853,28 @@ public abstract class AbstractXMLUtilities extends AbstractUtilities {
|
||||||
throw new NotFoundException();
|
throw new NotFoundException();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final Charset encoding = Charset.forName("UTF-8");
|
||||||
|
|
||||||
final ByteArrayOutputStream bos = new ByteArrayOutputStream();
|
final ByteArrayOutputStream bos = new ByteArrayOutputStream();
|
||||||
|
final OutputStreamWriter writer = new OutputStreamWriter(bos, encoding);
|
||||||
|
|
||||||
|
writer.write("<?xml version=\"1.0\" encoding=\"utf-8\"?>".toCharArray());
|
||||||
|
|
||||||
if (forceFeed || links.size() > 1) {
|
if (forceFeed || links.size() > 1) {
|
||||||
// build a feed
|
// build a feed
|
||||||
bos.write("<?xml version=\"1.0\" encoding=\"utf-8\"?>".getBytes());
|
|
||||||
|
|
||||||
bos.write(("<feed xml:base=\"" + Constants.get(version, ConstantKey.DEFAULT_SERVICE_URL) + "\" "
|
writer.write(("<feed xml:base=\"" + Constants.get(version, ConstantKey.DEFAULT_SERVICE_URL) + "\" "
|
||||||
+ "xmlns=\"http://www.w3.org/2005/Atom\" "
|
+ "xmlns=\"http://www.w3.org/2005/Atom\" "
|
||||||
+ "xmlns:d=\"http://schemas.microsoft.com/ado/2007/08/dataservices\" "
|
+ "xmlns:d=\"http://schemas.microsoft.com/ado/2007/08/dataservices\" "
|
||||||
+ "xmlns:m=\"http://schemas.microsoft.com/ado/2007/08/dataservices/metadata\">")
|
+ "xmlns:m=\"http://schemas.microsoft.com/ado/2007/08/dataservices/metadata\">")
|
||||||
.getBytes());
|
.toCharArray());
|
||||||
|
|
||||||
bos.write(("<id>" + Constants.get(version, ConstantKey.DEFAULT_SERVICE_URL) + "entityset(entityid)/" + linkName
|
writer.write(("<id>" + Constants.get(version, ConstantKey.DEFAULT_SERVICE_URL) + "entityset(entityid)/" + linkName
|
||||||
+ "</id>").getBytes());
|
+ "</id>").toCharArray());
|
||||||
|
|
||||||
bos.write(("<title type=\"text\">" + linkName + "</title>").getBytes());
|
writer.write(("<title type=\"text\">" + linkName + "</title>").toCharArray());
|
||||||
bos.write("<updated>2014-03-03T13:40:49Z</updated>".getBytes());
|
writer.write("<updated>2014-03-03T13:40:49Z</updated>".toCharArray());
|
||||||
bos.write(("<link rel=\"self\" title=\"" + linkName + "\" href=\"" + linkName + "\" />").getBytes());
|
writer.write(("<link rel=\"self\" title=\"" + linkName + "\" href=\"" + linkName + "\" />").toCharArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
for (String link : links) {
|
for (String link : links) {
|
||||||
|
@ -882,7 +888,7 @@ public abstract class AbstractXMLUtilities extends AbstractUtilities {
|
||||||
Collections.<String>singletonList("entry"),
|
Collections.<String>singletonList("entry"),
|
||||||
0, 1, 1).getValue();
|
0, 1, 1).getValue();
|
||||||
|
|
||||||
IOUtils.copy(entry.toStream(), bos);
|
IOUtils.copy(entry.toStream(), writer, encoding);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// log and ignore link
|
// log and ignore link
|
||||||
LOG.warn("Error parsing uri {}", link, e);
|
LOG.warn("Error parsing uri {}", link, e);
|
||||||
|
@ -892,12 +898,15 @@ public abstract class AbstractXMLUtilities extends AbstractUtilities {
|
||||||
if (forceFeed || links.size() > 1) {
|
if (forceFeed || links.size() > 1) {
|
||||||
|
|
||||||
if (StringUtils.isNotBlank(next)) {
|
if (StringUtils.isNotBlank(next)) {
|
||||||
bos.write(String.format("<link rel=\"next\" href=\"%s\" />", next).getBytes());
|
writer.write(String.format("<link rel=\"next\" href=\"%s\" />", next).toCharArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
bos.write("</feed>".getBytes());
|
writer.write("</feed>".toCharArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
writer.flush();
|
||||||
|
writer.close();
|
||||||
|
|
||||||
return new ByteArrayInputStream(bos.toByteArray());
|
return new ByteArrayInputStream(bos.toByteArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1227,7 +1236,7 @@ public abstract class AbstractXMLUtilities extends AbstractUtilities {
|
||||||
final XMLEventWriter writer = getEventWriter(bos);
|
final XMLEventWriter writer = getEventWriter(bos);
|
||||||
|
|
||||||
final XMLEventFactory eventFactory = XMLEventFactory.newInstance();
|
final XMLEventFactory eventFactory = XMLEventFactory.newInstance();
|
||||||
writer.add(eventFactory.createStartDocument("UTF-8", "1.0"));
|
writer.add(eventFactory.createStartDocument("utf-8", "1.0"));
|
||||||
writer.add(property.getStart());
|
writer.add(property.getStart());
|
||||||
|
|
||||||
if (property.getStart().getAttributeByName(new QName(
|
if (property.getStart().getAttributeByName(new QName(
|
||||||
|
|
|
@ -183,7 +183,7 @@ public abstract class Commons {
|
||||||
links.set("value", uris);
|
links.set("value", uris);
|
||||||
}
|
}
|
||||||
|
|
||||||
return IOUtils.toInputStream(links.toString());
|
return IOUtils.toInputStream(links.toString(), "UTf-8");
|
||||||
}
|
}
|
||||||
|
|
||||||
public static InputStream changeFormat(final InputStream is, final Accept target) {
|
public static InputStream changeFormat(final InputStream is, final Accept target) {
|
||||||
|
@ -197,7 +197,7 @@ public abstract class Commons {
|
||||||
final JsonNode node =
|
final JsonNode node =
|
||||||
changeFormat((ObjectNode) mapper.readTree(new ByteArrayInputStream(bos.toByteArray())), target);
|
changeFormat((ObjectNode) mapper.readTree(new ByteArrayInputStream(bos.toByteArray())), target);
|
||||||
|
|
||||||
return IOUtils.toInputStream(node.toString());
|
return IOUtils.toInputStream(node.toString(), "UTF-8");
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Error changing format", e);
|
LOG.error("Error changing format", e);
|
||||||
return new ByteArrayInputStream(bos.toByteArray());
|
return new ByteArrayInputStream(bos.toByteArray());
|
||||||
|
|
|
@ -20,6 +20,10 @@ package org.apache.olingo.fit.utils;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.nio.charset.Charset;
|
||||||
|
import java.nio.charset.CharsetDecoder;
|
||||||
|
import java.nio.charset.CodingErrorAction;
|
||||||
import javax.xml.stream.XMLEventReader;
|
import javax.xml.stream.XMLEventReader;
|
||||||
import javax.xml.stream.XMLInputFactory;
|
import javax.xml.stream.XMLInputFactory;
|
||||||
import javax.xml.stream.XMLStreamException;
|
import javax.xml.stream.XMLStreamException;
|
||||||
|
@ -28,6 +32,8 @@ import org.apache.commons.io.IOUtils;
|
||||||
|
|
||||||
public class XMLEventReaderWrapper implements XMLEventReader {
|
public class XMLEventReaderWrapper implements XMLEventReader {
|
||||||
|
|
||||||
|
private static Charset encoding = Charset.forName("UTF-8");
|
||||||
|
|
||||||
public final static String CONTENT = "CONTENT_TAG";
|
public final static String CONTENT = "CONTENT_TAG";
|
||||||
|
|
||||||
public final static String CONTENT_STAG = "<" + CONTENT + ">";
|
public final static String CONTENT_STAG = "<" + CONTENT + ">";
|
||||||
|
@ -43,12 +49,17 @@ public class XMLEventReaderWrapper implements XMLEventReader {
|
||||||
factory.setProperty(XMLInputFactory.IS_VALIDATING, false);
|
factory.setProperty(XMLInputFactory.IS_VALIDATING, false);
|
||||||
factory.setProperty(XMLInputFactory.IS_NAMESPACE_AWARE, false);
|
factory.setProperty(XMLInputFactory.IS_NAMESPACE_AWARE, false);
|
||||||
|
|
||||||
|
final CharsetDecoder decoder = encoding.newDecoder();
|
||||||
|
decoder.onMalformedInput(CodingErrorAction.IGNORE);
|
||||||
|
decoder.onUnmappableCharacter(CodingErrorAction.IGNORE);
|
||||||
|
|
||||||
this.wrapped = factory.createXMLEventReader(
|
InputStreamReader reader = new InputStreamReader(
|
||||||
new ByteArrayInputStream(
|
new ByteArrayInputStream((XMLEventReaderWrapper.CONTENT_STAG
|
||||||
(XMLEventReaderWrapper.CONTENT_STAG
|
+ IOUtils.toString(stream, encoding).replaceAll("^<\\?xml.*\\?>", "")
|
||||||
+ IOUtils.toString(stream).replaceAll("^<\\?xml.*\\?>", "")
|
+ XMLEventReaderWrapper.CONTENT_ETAG).getBytes(encoding)),
|
||||||
+ XMLEventReaderWrapper.CONTENT_ETAG).getBytes()));
|
decoder);
|
||||||
|
|
||||||
|
this.wrapped = factory.createXMLEventReader(reader);
|
||||||
|
|
||||||
init();
|
init();
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,9 @@ import java.io.ByteArrayInputStream;
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
import java.io.OutputStreamWriter;
|
import java.io.OutputStreamWriter;
|
||||||
|
import java.nio.charset.Charset;
|
||||||
import javax.xml.stream.XMLEventReader;
|
import javax.xml.stream.XMLEventReader;
|
||||||
import javax.xml.stream.XMLStreamException;
|
import javax.xml.stream.XMLStreamException;
|
||||||
import javax.xml.stream.events.EndElement;
|
import javax.xml.stream.events.EndElement;
|
||||||
|
@ -38,6 +40,8 @@ public class XmlElement {
|
||||||
*/
|
*/
|
||||||
protected static final Logger LOG = LoggerFactory.getLogger(XmlElement.class);
|
protected static final Logger LOG = LoggerFactory.getLogger(XmlElement.class);
|
||||||
|
|
||||||
|
private static Charset encoding = Charset.forName("UTF-8");
|
||||||
|
|
||||||
private StartElement start;
|
private StartElement start;
|
||||||
|
|
||||||
private EndElement end;
|
private EndElement end;
|
||||||
|
@ -70,20 +74,26 @@ public class XmlElement {
|
||||||
|
|
||||||
public void setContent(final InputStream content) throws IOException {
|
public void setContent(final InputStream content) throws IOException {
|
||||||
this.content.reset();
|
this.content.reset();
|
||||||
IOUtils.copyLarge(content, this.content);
|
|
||||||
content.close();
|
final InputStreamReader reader = new InputStreamReader(content, encoding);
|
||||||
|
final OutputStreamWriter writer = new OutputStreamWriter(this.content, encoding);
|
||||||
|
IOUtils.copyLarge(reader, writer);
|
||||||
|
|
||||||
|
writer.flush();
|
||||||
|
IOUtils.closeQuietly(reader);
|
||||||
|
IOUtils.closeQuietly(writer);
|
||||||
|
IOUtils.closeQuietly(content);
|
||||||
}
|
}
|
||||||
|
|
||||||
public InputStream toStream() throws Exception {
|
public InputStream toStream() throws Exception {
|
||||||
InputStream res;
|
InputStream res;
|
||||||
try {
|
try {
|
||||||
final ByteArrayOutputStream bos = new ByteArrayOutputStream();
|
final ByteArrayOutputStream bos = new ByteArrayOutputStream();
|
||||||
final OutputStreamWriter osw = new OutputStreamWriter(bos);
|
final OutputStreamWriter osw = new OutputStreamWriter(bos, encoding);
|
||||||
|
|
||||||
getStart().writeAsEncodedUnicode(osw);
|
getStart().writeAsEncodedUnicode(osw);
|
||||||
osw.flush();
|
|
||||||
|
|
||||||
IOUtils.copy(getContent(), bos);
|
IOUtils.copy(getContent(), osw, encoding);
|
||||||
|
|
||||||
getEnd().writeAsEncodedUnicode(osw);
|
getEnd().writeAsEncodedUnicode(osw);
|
||||||
osw.flush();
|
osw.flush();
|
||||||
|
|
|
@ -39,7 +39,6 @@ import org.apache.olingo.client.api.uri.CommonURIBuilder;
|
||||||
import org.apache.olingo.commons.api.domain.CommonODataEntity;
|
import org.apache.olingo.commons.api.domain.CommonODataEntity;
|
||||||
import org.apache.olingo.commons.api.domain.v3.ODataEntity;
|
import org.apache.olingo.commons.api.domain.v3.ODataEntity;
|
||||||
import org.apache.olingo.commons.api.domain.v3.ODataEntitySet;
|
import org.apache.olingo.commons.api.domain.v3.ODataEntitySet;
|
||||||
import org.junit.Ignore;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
public class AsyncTestITCase extends AbstractTestITCase {
|
public class AsyncTestITCase extends AbstractTestITCase {
|
||||||
|
|
13
pom.xml
13
pom.xml
|
@ -331,6 +331,19 @@
|
||||||
</execution>
|
</execution>
|
||||||
</executions>
|
</executions>
|
||||||
</plugin>
|
</plugin>
|
||||||
|
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.apache.maven.plugins</groupId>
|
||||||
|
<artifactId>maven-resources-plugin</artifactId>
|
||||||
|
<version>2.6</version>
|
||||||
|
<configuration>
|
||||||
|
<encoding>UTF-8</encoding>
|
||||||
|
<useDefaultDelimiters>false</useDefaultDelimiters>
|
||||||
|
<delimiters>
|
||||||
|
<delimiter>${*}</delimiter>
|
||||||
|
</delimiters>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
|
||||||
</plugins>
|
</plugins>
|
||||||
</pluginManagement>
|
</pluginManagement>
|
||||||
|
|
Loading…
Reference in New Issue