Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(jsii): unable to use nested types from dependencies #1866

Merged
merged 13 commits into from
Aug 12, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 13 additions & 3 deletions .github/workflows/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -59,8 +59,10 @@ jobs:
${{ steps.cache-locations.outputs.pip-cache }}
${{ steps.cache-locations.outputs.yarn-cache }}
~/.m2/repository
!~/.m2/repository/software/amazon/jsii/
~/.nuget/packages
key: ${{ runner.os }}-node@12-python@3.6-${{ hashFiles('**/yarn.lock') }}
!~/.nuget/packages/amazon.jsii.*
key: ${{ runner.os }}-node@12-python@3.6-${{ hashFiles('**/yarn.lock', '**/Directory.Build.targets') }}
restore-keys: |-
${{ runner.os }}-node@12-python@3.6-
${{ runner.os }}-node@12-
Expand Down Expand Up @@ -130,8 +132,10 @@ jobs:
${{ steps.cache-locations.outputs.pip-cache }}
${{ steps.cache-locations.outputs.yarn-cache }}
~/.m2/repository
!~/.m2/repository/software/amazon/jsii/
~/.nuget/packages
key: ${{ runner.os }}-node@12-python@3.6-${{ hashFiles('**/yarn.lock') }}
!~/.nuget/packages/amazon.jsii.*
key: ${{ runner.os }}-node@12-python@3.6-${{ hashFiles('**/yarn.lock', '**/Directory.Build.targets') }}
restore-keys: |-
${{ runner.os }}-node@12-python@3.6-
${{ runner.os }}-node@12-
Expand Down Expand Up @@ -276,9 +280,11 @@ jobs:
${{ steps.cache-locations.outputs.pip-cache }}
${{ steps.cache-locations.outputs.yarn-cache }}
~/.m2/repository
!~/.m2/repository/software/amazon/jsii/
~/.nuget/packages
!~/.nuget/packages/amazon.jsii.*
# Not including .NET / Java in the cache keys, those artifacts are SDK-version-independent
key: ${{ runner.os }}-node@${{ matrix.node }}-python@${{ matrix.python }}-${{ hashFiles('**/yarn.lock') }}
key: ${{ runner.os }}-node@${{ matrix.node }}-python@${{ matrix.python }}-${{ hashFiles('**/yarn.lock', '**/Directory.Build.targets') }}
restore-keys: |-
${{ runner.os }}-node@${{ matrix.node }}-python@${{ matrix.python }}-
${{ runner.os }}-node@${{ matrix.node }}-
Expand Down Expand Up @@ -353,6 +359,10 @@ jobs:
# Run the integration test
- name: Install Dependencies
run: |-
# Python tools used during packaging
python3 -m pip install --upgrade pipx setuptools twine wheel

# TypeScript project dependencies
yarn install --frozen-lockfile
working-directory: aws-cdk
- name: Install Tested Packages
Expand Down
29 changes: 20 additions & 9 deletions packages/@scope/jsii-calc-lib/lib/submodule/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,26 @@ export interface ReflectableEntry {
}

export class Reflector {
public constructor() { }

public asMap(reflectable: IReflectable): Record<string, unknown> {
return reflectable.entries.reduce(
(mapping, entry) => {
mapping[entry.key] = entry.value;
return mapping;
},
{} as Record<string, unknown>,
);
return reflectable.entries.reduce((mapping, entry) => {
mapping[entry.key] = entry.value;
return mapping;
}, {} as Record<string, unknown>);
}
}

/**
* This class is here to show we can use nested classes across module boundaries.
*/
export class NestingClass {
private constructor() {}
}
// eslint-disable-next-line @typescript-eslint/no-namespace
export namespace NestingClass {
/**
* This class is here to show we can use nested classes across module boundaries.
*/
export class NestedClass {
public readonly property: string = 'property';
}
}
59 changes: 53 additions & 6 deletions packages/@scope/jsii-calc-lib/test/assembly.jsii
Original file line number Diff line number Diff line change
Expand Up @@ -574,6 +574,57 @@
}
]
},
"@scope/jsii-calc-lib.submodule.NestingClass": {
"assembly": "@scope/jsii-calc-lib",
"docs": {
"stability": "deprecated",
"summary": "This class is here to show we can use nested classes across module boundaries."
},
"fqn": "@scope/jsii-calc-lib.submodule.NestingClass",
"kind": "class",
"locationInModule": {
"filename": "lib/submodule/index.ts",
"line": 22
},
"name": "NestingClass",
"namespace": "submodule"
},
"@scope/jsii-calc-lib.submodule.NestingClass.NestedClass": {
"assembly": "@scope/jsii-calc-lib",
"docs": {
"stability": "deprecated",
"summary": "This class is here to show we can use nested classes across module boundaries."
},
"fqn": "@scope/jsii-calc-lib.submodule.NestingClass.NestedClass",
"initializer": {
"docs": {
"stability": "deprecated"
}
},
"kind": "class",
"locationInModule": {
"filename": "lib/submodule/index.ts",
"line": 30
},
"name": "NestedClass",
"namespace": "submodule.NestingClass",
"properties": [
{
"docs": {
"stability": "deprecated"
},
"immutable": true,
"locationInModule": {
"filename": "lib/submodule/index.ts",
"line": 31
},
"name": "property",
"type": {
"primitive": "string"
}
}
]
},
"@scope/jsii-calc-lib.submodule.ReflectableEntry": {
"assembly": "@scope/jsii-calc-lib",
"datatype": true,
Expand Down Expand Up @@ -630,10 +681,6 @@
"initializer": {
"docs": {
"stability": "deprecated"
},
"locationInModule": {
"filename": "lib/submodule/index.ts",
"line": 11
}
},
"kind": "class",
Expand All @@ -648,7 +695,7 @@
},
"locationInModule": {
"filename": "lib/submodule/index.ts",
"line": 13
"line": 11
},
"name": "asMap",
"parameters": [
Expand Down Expand Up @@ -676,5 +723,5 @@
}
},
"version": "0.0.0",
"fingerprint": "fVfpIK7xUajlT1zkHIJ8uYJPvy0gLgEe5BM8afu1mVg="
"fingerprint": "f/4VuNiOkSgTgLR80loQUAzAuzFi+25rmfLcRWKDCrY="
}
1 change: 1 addition & 0 deletions packages/jsii-calc/lib/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ export * from './calculator';
export * from './compliance';
export * from './documented';
export * from './erasures';
export * from './nested-class';
export * from './stability';
export * from './submodules';

Expand Down
9 changes: 9 additions & 0 deletions packages/jsii-calc/lib/nested-class.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { submodule } from '@scope/jsii-calc-lib';

export class NestedClassInstance {
public static makeInstance(): submodule.NestingClass.NestedClass {
return new submodule.NestingClass.NestedClass();
}

private constructor() {}
}
35 changes: 33 additions & 2 deletions packages/jsii-calc/test/assembly.jsii
Original file line number Diff line number Diff line change
Expand Up @@ -196,7 +196,7 @@
"jsii-calc.submodule": {
"locationInModule": {
"filename": "lib/index.ts",
"line": 8
"line": 9
}
},
"jsii-calc.submodule.back_references": {
Expand Down Expand Up @@ -8439,6 +8439,37 @@
}
]
},
"jsii-calc.NestedClassInstance": {
"assembly": "jsii-calc",
"docs": {
"stability": "experimental"
},
"fqn": "jsii-calc.NestedClassInstance",
"kind": "class",
"locationInModule": {
"filename": "lib/nested-class.ts",
"line": 3
},
"methods": [
{
"docs": {
"stability": "experimental"
},
"locationInModule": {
"filename": "lib/nested-class.ts",
"line": 4
},
"name": "makeInstance",
"returns": {
"type": {
"fqn": "@scope/jsii-calc-lib.submodule.NestingClass.NestedClass"
}
},
"static": true
}
],
"name": "NestedClassInstance"
},
"jsii-calc.NestedStruct": {
"assembly": "jsii-calc",
"datatype": true,
Expand Down Expand Up @@ -13788,5 +13819,5 @@
}
},
"version": "0.0.0",
"fingerprint": "kQYWZjxtnycywR9qo/KXKyeVPmP6HoAefGhHN7SidkM="
"fingerprint": "NsqdwWgXi+kjrpLQtQ27eA/znULJ7TtXy03ht68N9Ms="
}
2 changes: 1 addition & 1 deletion packages/jsii-pacmak/lib/targets/dotnet.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ export class DotnetBuilder implements TargetBuilder {

// Build solution
logging.debug('Building .NET');
await shell('dotnet', ['build', '-c', 'Release'], {
await shell('dotnet', ['build', '--force', '-c', 'Release'], {
cwd: tempSourceDir.directory,
});

Expand Down
3 changes: 1 addition & 2 deletions packages/jsii-pacmak/lib/targets/dotnet/dotnetgenerator.ts
Original file line number Diff line number Diff line change
Expand Up @@ -283,7 +283,6 @@ export class DotNetGenerator extends Generator {

// Nested classes will be dealt with during calc code generation
const nested = this.isNested(cls);
const inner = nested ? ' static' : '';
const absPrefix = abstract ? ' abstract' : '';

this.openFileIfNeeded(className, namespace, nested);
Expand All @@ -294,7 +293,7 @@ export class DotNetGenerator extends Generator {
this.dotnetRuntimeGenerator.emitAttributesForClass(cls);

this.code.openBlock(
`public${inner}${absPrefix} class ${className}${implementsExpr}`,
`public${absPrefix} class ${className}${implementsExpr}`,
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

C# does not allow static member classes to declare protected members (our contract includes some, so that was bad). The presence of the static keyword here was a Java-ism, since nested classes in C# (with or without static) are actually semantically related to Java static nested classes (the syntactic sugar that Java has for non-static nested classes does not exist in C#).

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should have been a separate PR, don'tcha agree?

Copy link
Contributor Author

@RomainMuller RomainMuller Aug 11, 2020

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Except that separate PR's test would not have been able to pass without the other changes in this PR (cannot test I can generate a valid nested class if I can't compile it), and vice-versa (cannot check I generate valid code for a nested class if I generate invalid code for a nested class)...

);

// Compute the class parameters
Expand Down
27 changes: 22 additions & 5 deletions packages/jsii-pacmak/lib/targets/python.ts
Original file line number Diff line number Diff line change
Expand Up @@ -48,13 +48,25 @@ export default class Python extends Target {
await shell('python3', ['setup.py', 'sdist', '--dist-dir', outDir], {
cwd: sourceDir,
});
await shell('python3', ['setup.py', 'bdist_wheel', '--dist-dir', outDir], {
cwd: sourceDir,
});
await shell(
'python3',
['-m', 'pip', 'wheel', '--no-deps', '--wheel-dir', outDir, sourceDir],
{
cwd: sourceDir,
},
);
if (await isPresent('twine', sourceDir)) {
await shell('twine', ['check', path.join(outDir, '*')], {
cwd: sourceDir,
});
} else if (await isPresent('pipx', sourceDir)) {
await shell('pipx', ['run', 'twine', 'check', path.join(outDir, '*')], {
cwd: sourceDir,
env: {
...process.env,
PIPX_HOME: path.join(sourceDir, '.pipx'),
},
});
} else {
warn(
'Unable to validate distribution packages because `twine` is not present. ' +
Expand Down Expand Up @@ -1649,6 +1661,9 @@ class Package {
(this.metadata.author.email !== undefined
? `<${this.metadata.author.email}>`
: ''),
bdist_wheel: {
universal: true,
},
project_urls: {
Source: this.metadata.repository.url,
},
Expand All @@ -1659,7 +1674,9 @@ class Package {
install_requires: [
`jsii${toPythonVersionRange(`^${jsiiVersionSimple}`)}`,
'publication>=0.0.3',
].concat(dependencies),
]
.concat(dependencies)
.sort(),
classifiers: [
'Intended Audience :: Developers',
'Operating System :: OS Independent',
Expand Down Expand Up @@ -1719,7 +1736,7 @@ class Package {
// TODO: Might be easier to just use a TOML library to write this out.
code.openFile('pyproject.toml');
code.line('[build-system]');
code.line('requires = ["setuptools >= 38.6.0", "wheel >= 0.31.0"]');
code.line('requires = ["setuptools >= 49.3.1", "wheel >= 0.34.2"]');
code.line('build-backend = "setuptools.build_meta"');
code.closeFile('pyproject.toml');

Expand Down
5 changes: 3 additions & 2 deletions packages/jsii-pacmak/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,9 @@
"watch": "tsc --build -w",
"lint": "eslint . --ext .js,.ts --ignore-path=.gitignore",
"lint:fix": "yarn lint --fix",
"test": "jest && bash test/build-test.sh",
"test:update": "jest -u && bash test/build-test.sh",
"test": "jest && npm run test:build",
"test:build": "bash test/build-test.sh",
"test:update": "jest -u && npm run test:build",
"package": "package-js"
},
"dependencies": {
Expand Down
Loading