Skip to content

Commit

Permalink
Merge pull request #3 from KavinduZoysa/gimantha-table-issue
Browse files Browse the repository at this point in the history
Fix test failures in 38390
  • Loading branch information
gimantha authored Jan 18, 2023
2 parents 2d2f331 + f81b948 commit 3c57ded
Show file tree
Hide file tree
Showing 1,710 changed files with 100,839 additions and 103,834 deletions.
16 changes: 4 additions & 12 deletions .github/workflows/automate_issue_labels.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,20 +10,12 @@ jobs:
steps:
- uses: actions/checkout@v2

- name: Check for Team label inclusion
run: |
if ${{ contains(join(github.event.issue.labels.*.name, ','), 'Team/') }} == true; then
echo "team_label_added=true" >> $GITHUB_ENV
else
echo "team_label_added=false" >> $GITHUB_ENV
fi
- name: Check for Type label inclusion
if: ${{ !(contains(join(github.event.issue.labels.*.name, ','), 'Type/')) }}
run: gh issue edit $ISSUE --add-label "needTriage"

- name: Check for Compilation related issue
if: ${{ contains(github.event.issue.body, '-> Compilation') && {{ env.team_label_added == false }} }}
if: ${{ contains(github.event.issue.body, '-> Compilation') && !contains(join(github.event.issue.labels.*.name, ','), 'Team/') }}
run: |
gh issue edit $ISSUE --add-label "needTriage"
gh issue edit $ISSUE --add-label "userCategory/Compilation"
Expand All @@ -46,7 +38,7 @@ jobs:
ISSUE: ${{ github.event.issue.number }}

- name: Check for Central related isssue
if: ${{ contains(github.event.issue.body, '-> Central') && {{ env.team_label_added == false }} }}
if: ${{ contains(github.event.issue.body, '-> Central') && !contains(join(github.event.issue.labels.*.name, ','), 'Team/') }}
run: |
gh issue edit $ISSUE --add-label "needTriage"
gh issue edit $ISSUE --add-label "userCategory/Central"
Expand Down Expand Up @@ -142,7 +134,7 @@ jobs:
ISSUE: ${{ github.event.issue.number }}

- name: Check for Editor related issue
if: ${{ contains(github.event.issue.body, '-> Editor') && {{ env.team_label_added == false }} }}
if: ${{ contains(github.event.issue.body, '-> Editor') && !contains(join(github.event.issue.labels.*.name, ','), 'Team/') }}
run: |
gh issue edit $ISSUE --add-label "needTriage"
gh issue edit $ISSUE --add-label "userCategory/Editor"
Expand Down Expand Up @@ -174,7 +166,7 @@ jobs:
ISSUE: ${{ github.event.issue.number }}

- name: Check for other issues
if: ${{ contains(github.event.issue.body, '-> Other Area') && {{ env.team_label_added == false }} }}
if: ${{ contains(github.event.issue.body, '-> Other Area') && !contains(join(github.event.issue.labels.*.name, ','), 'Team/') }}
run: gh issue edit $ISSUE --add-label "needTriage"
env:
GITHUB_TOKEN: ${{ secrets.BALLERINA_BOT_TOKEN }}
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/language_server_simulator.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ jobs:
strategy:
fail-fast: false
matrix:
branch: ["master", "2201.1.x", "2201.2.x", "2201.2.2-stage", "2201.3.x", "2201.3.0-stage"]
branch: ["master", "2201.2.x", "2201.3.x", "2201.3.0-stage"]
skipGenerators: ["", "IMPORT_STATEMENT"]

steps:
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/nightly_publish_timestamped_release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ jobs:
fail-fast: false
max-parallel: 4
matrix:
branch: ['master', '2201.0.x', '2201.1.x', '2201.2.x']
branch: ['master', '2201.2.x', '2201.3.x']
timeout-minutes: 240
if: github.repository_owner == 'ballerina-platform'
steps:
Expand Down
18 changes: 9 additions & 9 deletions .github/workflows/pull_request_full_build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -72,15 +72,15 @@ jobs:
do git clone https://github.com/ballerina-platform/${module_name}.git; \
done
- name: Checkout non-default branch
run: |
for module_name in $(jq -r '.standard_library| .[] | select(.level==${{ matrix.level }}) | .name' extensions.json); \
do
cd $module_name
git fetch origin
git checkout -t origin/update4 || :
cd ..
done
# - name: Checkout non-default branch
# run: |
# for module_name in $(jq -r '.standard_library| .[] | select(.level==${{ matrix.level }}) | .name' extensions.json); \
# do
# cd $module_name
# git fetch origin
# git checkout -t origin/update4 || :
# cd ..
# done

- name: Update Lang Version in Module
run: |
Expand Down
1 change: 1 addition & 0 deletions .github/workflows/pull_request_ubuntu_build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ on:
- 2201.[0-9]+.x
- 2201.[0-9]+.[0-9]+-stage
- native-build
- revert-client-decl-master

jobs:
ubuntu_build:
Expand Down
1 change: 1 addition & 0 deletions .github/workflows/pull_request_windows_build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ on:
- 2201.[0-9]+.x
- 2201.[0-9]+.[0-9]+-stage
- native-build
- revert-client-decl-master

jobs:
windows_build:
Expand Down
1 change: 0 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@ velocity.log
/composer/modules/web/dist-electron
extractedDistribution
misc/testerina/modules/report-tools/node_modules/
generated

# gradle
.gradle
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import io.ballerina.runtime.api.types.ObjectType;
import io.ballerina.runtime.api.types.Type;
import io.ballerina.runtime.api.utils.StringUtils;
import io.ballerina.runtime.api.utils.TypeUtils;
import io.ballerina.runtime.api.values.BError;
import io.ballerina.runtime.api.values.BFunctionPointer;
import io.ballerina.runtime.api.values.BFuture;
Expand Down Expand Up @@ -183,7 +184,7 @@ public BFuture invokeMethodAsync(BObject object, String methodName, String stran
Type returnType, Object... args) {
try {
validateArgs(object, methodName);
ObjectType objectType = object.getType();
ObjectType objectType = (ObjectType) TypeUtils.getReferredType(object.getType());
boolean isIsolated = objectType.isIsolated() && objectType.isIsolated(methodName);
FutureValue future = scheduler.createFuture(null, callback, properties, returnType, strandName, metadata);
AsyncUtils.getArgsWithDefaultValues(scheduler, object, methodName, new Callback() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
import io.ballerina.runtime.api.types.ArrayType;
import io.ballerina.runtime.api.types.JsonType;
import io.ballerina.runtime.api.types.MapType;
import io.ballerina.runtime.api.types.ReferenceType;
import io.ballerina.runtime.api.types.StructureType;
import io.ballerina.runtime.api.types.TableType;
import io.ballerina.runtime.api.types.Type;
Expand Down Expand Up @@ -284,16 +285,23 @@ public static Object convertToJson(Object value, List<TypeValuePair> unresolvedV
return null;
}
Type sourceType = TypeChecker.getType(value);
if (sourceType.getTag() <= TypeTags.BOOLEAN_TAG && TypeChecker.checkIsType(value, jsonType)) {
if (TypeUtils.getReferredType(sourceType).getTag() <= TypeTags.BOOLEAN_TAG && TypeChecker.checkIsType(value,
jsonType)) {
return value;
}
TypeValuePair typeValuePair = new TypeValuePair(value, jsonType);
if (unresolvedValues.contains(typeValuePair)) {
throw createCyclicValueReferenceError(value);
}
unresolvedValues.add(typeValuePair);
Object newValue;
Object newValue = getJsonObject(value, unresolvedValues, jsonType, sourceType);
unresolvedValues.remove(typeValuePair);
return newValue;
}

private static Object getJsonObject(Object value, List<TypeValuePair> unresolvedValues, Type jsonType,
Type sourceType) {
Object newValue;
switch (sourceType.getTag()) {
case TypeTags.XML_TAG:
case TypeTags.XML_ELEMENT_TAG:
Expand All @@ -309,7 +317,7 @@ public static Object convertToJson(Object value, List<TypeValuePair> unresolvedV
break;
case TypeTags.TABLE_TAG:
BTable bTable = (BTable) value;
Type constrainedType = ((TableType) bTable.getType()).getConstrainedType();
Type constrainedType = ((TableType) sourceType).getConstrainedType();
if (constrainedType.getTag() == TypeTags.MAP_TAG) {
newValue = convertMapConstrainedTableToJson((BTable) value, unresolvedValues);
} else {
Expand All @@ -324,11 +332,14 @@ public static Object convertToJson(Object value, List<TypeValuePair> unresolvedV
case TypeTags.MAP_TAG:
newValue = convertMapToJson((BMap<?, ?>) value, unresolvedValues);
break;
case TypeTags.TYPE_REFERENCED_TYPE_TAG:
newValue = getJsonObject(value, unresolvedValues, jsonType,
((ReferenceType) sourceType).getReferredType());
break;
case TypeTags.ERROR_TAG:
default:
throw createConversionError(value, jsonType);
}
unresolvedValues.remove(typeValuePair);
return newValue;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,7 @@ public static String getStringValue(Object value, BLink parent) {
return "";
}

Type type = TypeChecker.getType(value);
Type type = TypeUtils.getReferredType(TypeChecker.getType(value));

if (type.getTag() == TypeTags.STRING_TAG) {
return ((BString) value).getValue();
Expand Down Expand Up @@ -203,7 +203,7 @@ public static String getStringValue(Object value, BLink parent) {

if (type.getTag() == TypeTags.OBJECT_TYPE_TAG) {
BObject objectValue = (BObject) value;
ObjectType objectType = objectValue.getType();
ObjectType objectType = (ObjectType) TypeUtils.getReferredType(objectValue.getType());
for (MethodType func : objectType.getMethods()) {
if (func.getName().equals(TO_STRING) && func.getParameters().length == 0 &&
func.getType().getReturnType().getTag() == TypeTags.STRING_TAG) {
Expand All @@ -228,7 +228,7 @@ public static String getExpressionStringValue(Object value, BLink parent) {
return "()";
}

Type type = TypeChecker.getType(value);
Type type = TypeUtils.getReferredType(TypeChecker.getType(value));

if (type.getTag() == TypeTags.STRING_TAG) {
return "\"" + ((BString) value).getValue() + "\"";
Expand Down Expand Up @@ -274,7 +274,7 @@ public static String getExpressionStringValue(Object value, BLink parent) {

if (type.getTag() == TypeTags.OBJECT_TYPE_TAG) {
AbstractObjectValue objectValue = (AbstractObjectValue) value;
ObjectType objectType = objectValue.getType();
ObjectType objectType = (ObjectType) TypeUtils.getReferredType(objectValue.getType());
for (MethodType func : objectType.getMethods()) {
if (func.getName().equals(TO_STRING) && func.getParameters().length == 0 &&
func.getType().getReturnType().getTag() == TypeTags.STRING_TAG) {
Expand Down Expand Up @@ -357,7 +357,7 @@ public static Object parseExpressionStringValue(String value, BLink parent) thro
public static String getJsonString(Object value) {
Object jsonValue = JsonUtils.convertToJson(value, new ArrayList<>());

Type type = TypeChecker.getType(jsonValue);
Type type = TypeUtils.getReferredType(TypeChecker.getType(jsonValue));
switch (type.getTag()) {
case TypeTags.NULL_TAG:
return "null";
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
import static io.ballerina.runtime.api.PredefinedTypes.TYPE_INT;
import static io.ballerina.runtime.api.PredefinedTypes.TYPE_JSON;
import static io.ballerina.runtime.api.PredefinedTypes.TYPE_MAP;
import static io.ballerina.runtime.api.PredefinedTypes.TYPE_NEVER;
import static io.ballerina.runtime.api.PredefinedTypes.TYPE_NULL;
import static io.ballerina.runtime.api.PredefinedTypes.TYPE_STREAM;
import static io.ballerina.runtime.api.PredefinedTypes.TYPE_STRING;
Expand All @@ -55,23 +56,26 @@ private TypeUtils() {
}

public static boolean isValueType(Type type) {
if (type == TYPE_INT || type == TYPE_BYTE ||
type == TYPE_FLOAT ||
type == TYPE_DECIMAL || type == TYPE_STRING ||
type == TYPE_BOOLEAN) {
return true;
}

if (type != null && type.getTag() == TypeTags.FINITE_TYPE_TAG) {
// All the types in value space should be value types.
for (Object value : ((BFiniteType) type).valueSpace) {
if (!isValueType(TypeChecker.getType(value))) {
return false;
Type referredType = TypeUtils.getReferredType(type);
switch (referredType.getTag()) {
case TypeTags.INT_TAG:
case TypeTags.BYTE_TAG:
case TypeTags.FLOAT_TAG:
case TypeTags.DECIMAL_TAG:
case TypeTags.BOOLEAN_TAG:
case TypeTags.STRING_TAG:
return true;
case TypeTags.FINITE_TYPE_TAG:
for (Object value : ((BFiniteType) referredType).valueSpace) {
if (!isValueType(TypeChecker.getType(value))) {
return false;
}
}
}
return true;
return true;
default:
return false;

}
return false;
}

public static Type getTypeFromName(String typeName) {
Expand Down Expand Up @@ -110,6 +114,8 @@ public static Type getTypeFromName(String typeName) {
return TYPE_ERROR;
case TypeConstants.ANYDATA_TNAME:
return TYPE_ANYDATA;
case TypeConstants.NEVER_TNAME:
return TYPE_NEVER;
default:
throw new IllegalStateException("Unknown type name");
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@
*/
package io.ballerina.runtime.api.values;

import io.ballerina.runtime.api.types.ObjectType;
import io.ballerina.runtime.api.types.Type;
import io.ballerina.runtime.internal.scheduling.Strand;
import io.ballerina.runtime.internal.values.RefValue;

Expand All @@ -36,7 +36,7 @@ public interface BObject extends RefValue {

BFuture start(Strand strand, String funcName, Object... args);

ObjectType getType();
Type getType();

Object get(BString fieldName);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ public BLock() {
public synchronized boolean lock(Strand strand) {
if (isLockFree() || lockedBySameContext(strand)) {
this.current.offerLast(strand);
strand.acquiredLockCount++;
return true;
}

Expand All @@ -54,7 +55,8 @@ public synchronized boolean lock(Strand strand) {

public synchronized void unlock() {
//current cannot be empty as unlock cannot be called without lock being called first.
this.current.removeLast();
Strand removedStrand = this.current.removeLast();
removedStrand.acquiredLockCount--;
if (!waitingForLock.isEmpty()) {
Strand strand = this.waitingForLock.removeFirst();
strand.scheduler.unblockStrand(strand);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,14 +50,9 @@ public BLock getLockFromMap(String lockName) {
});
}

public void panicIfInLock(String lockName, Strand strand) {
for (BLock lock : globalLockMap.values()) {
if (lock.isLockFree()) {
continue;
}
if (lock.lockedBySameContext(strand)) {
throw ErrorCreator.createError(BallerinaErrorReasons.ASYNC_CALL_INSIDE_LOCK);
}
public void panicIfInLock(Strand strand) {
if (strand.acquiredLockCount > 0) {
throw ErrorCreator.createError(BallerinaErrorReasons.ASYNC_CALL_INSIDE_LOCK);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
package io.ballerina.runtime.internal;

import io.ballerina.runtime.api.TypeTags;
import io.ballerina.runtime.api.utils.TypeUtils;
import io.ballerina.runtime.api.values.BString;
import io.ballerina.runtime.internal.values.ArrayValue;
import io.ballerina.runtime.internal.values.DecimalValue;
Expand Down Expand Up @@ -279,7 +280,7 @@ public void serialize(Object json) throws IOException {
return;
}

switch (TypeChecker.getType(json).getTag()) {
switch (TypeUtils.getReferredType(TypeChecker.getType(json)).getTag()) {
case TypeTags.ARRAY_TAG:
if (json instanceof StreamingJsonValue) {
((StreamingJsonValue) json).serialize(this);
Expand Down
Loading

0 comments on commit 3c57ded

Please sign in to comment.