Skip to content

Commit

Permalink
Merge pull request #42 from SasinduDilshara/fix_6890
Browse files Browse the repository at this point in the history
Fix CCE in arrays with refered types
  • Loading branch information
SasinduDilshara authored Sep 5, 2024
2 parents 2f18de5 + b251984 commit dc89791
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 4 deletions.
4 changes: 2 additions & 2 deletions ballerina/Dependencies.toml
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ modules = [
[[package]]
org = "ballerina"
name = "io"
version = "1.6.1"
version = "1.6.2"
scope = "testOnly"
dependencies = [
{org = "ballerina", name = "jballerina.java"},
Expand Down Expand Up @@ -116,7 +116,7 @@ modules = [
[[package]]
org = "ballerina"
name = "time"
version = "2.4.0"
version = "2.4.1"
scope = "testOnly"
dependencies = [
{org = "ballerina", name = "jballerina.java"}
Expand Down
23 changes: 23 additions & 0 deletions ballerina/tests/fromXml_test.bal
Original file line number Diff line number Diff line change
Expand Up @@ -3585,3 +3585,26 @@ isolated function testDuplicateField() {
test:assertTrue(err4 is Error);
test:assertEquals((<Error> err4).message(), "duplicate field 'name'");
}

type Ports record {|
PortContent[] port;
|};

@Namespace {
prefix: "ns1",
uri: "example1.com"
}
type PortContent record {|
string \#content;
|};

@test:Config
isolated function testTypeRefArray() {
string s = string `
<A xmlns:ns1="example1.com" xmlns:ns2="example2.com">
<ns1:port>1</ns1:port>
<ns1:port>1</ns1:port>
</A>`;
Ports|error rec = parseString(s);
test:assertEquals(rec, {"port":[{"#content":"1"},{"#content":"1"}]});
}
Original file line number Diff line number Diff line change
Expand Up @@ -357,9 +357,10 @@ private void convertTextAndUpdateCurrentNode(BMap<BString, Object> currentNode,
@SuppressWarnings("unchecked")
private void addTextToCurrentNodeIfExpTypeIsArray(ArrayType fieldType, BString bFieldName, BString bText,
XmlParserData xmlParserData) {
int elementTypeTag = TypeUtils.getReferredType(fieldType.getElementType()).getTag();
Type referredType = TypeUtils.getReferredType(fieldType.getElementType());
int elementTypeTag = referredType.getTag();
switch (elementTypeTag) {
case TypeTags.RECORD_TYPE_TAG -> handleContentFieldInRecordType((RecordType) fieldType.getElementType(),
case TypeTags.RECORD_TYPE_TAG -> handleContentFieldInRecordType((RecordType) referredType,
bText, xmlParserData);
case TypeTags.ANYDATA_TAG, TypeTags.JSON_TAG -> {
BArray tempArr = (BArray) ((BMap<BString, Object>) xmlParserData.nodesStack.peek()).get(bFieldName);
Expand Down

0 comments on commit dc89791

Please sign in to comment.