From f99d0ac435e2c65422af5d2f0f0a62cf5fcb6c48 Mon Sep 17 00:00:00 2001 From: Mira Leung Date: Fri, 28 Aug 2020 22:49:57 -0700 Subject: [PATCH] [ggj][codegen] feat: add settingsBuilder getters in ServiceStubSettings (#246) * feat: add factory var decl in ServiceStubSettings codegen * fix: prevent duplicate MethodDefinition annotations * feat: add descriptor fields to ServiceStubSettings codegen * feat: add starter Builder to ServiceStubSettings codegen * feat: add settings.builder decls to ServiceStubSettings codegen * feat: add first nested ctors to ServiceStubSettings codegen * feat: add GapicServiceConfig DS and processing * feat: integrate GapicServiceConfig into GapicContext, Parser, Composer * feat: initial param block, RetrySettingsComposer, test * fix!: refactor GapicRetrySettings * fix: recognize 1. or .1 double patterns * feat: support BlockStatement in ClassDef stmts * feat: add params block to ServiceStubSettings codegen * feat: add codes def to ServiceStubSettings codegen * feat: add initDefaults() to ServiceStubSettings codegen * feat: add LRO to ServiceStubSettings.Builder.initDefaults * feat: add third ServiceStubSettings.Builder(settings) ctor * feat: add createDefault() to ServiceStubSettings * feat: add ServiceStubSettings.applyToAllUnaryMethods method * feat: add ServiceStubSettings.unaryMethodSettingsBuilders() * feat: add ServiceStubSettings.build() * feat: add settingsBuilder getters in ServiceStubSettings --- .../ServiceStubSettingsClassComposer.java | 41 ++++++++++++++++- .../ServiceStubSettingsClassComposerTest.java | 46 +++++++++++++++++++ 2 files changed, 85 insertions(+), 2 deletions(-) diff --git a/src/main/java/com/google/api/generator/gapic/composer/ServiceStubSettingsClassComposer.java b/src/main/java/com/google/api/generator/gapic/composer/ServiceStubSettingsClassComposer.java index 9076b4c219..3aaa35301d 100644 --- a/src/main/java/com/google/api/generator/gapic/composer/ServiceStubSettingsClassComposer.java +++ b/src/main/java/com/google/api/generator/gapic/composer/ServiceStubSettingsClassComposer.java @@ -1170,8 +1170,8 @@ private static List createNestedClassMethods( nestedClassMethods.add(createNestedClassInitDefaultsMethod(service, serviceConfig, types)); nestedClassMethods.add(createNestedClassApplyToAllUnaryMethodsMethod(superType, types)); nestedClassMethods.add(createNestedClassUnaryMethodSettingsBuilderGetterMethod()); - - // TODO(miraleung): More methods. + nestedClassMethods.addAll( + createNestedClassSettingsBuilderGetterMethods(nestedMethodSettingsMemberVarExprs)); nestedClassMethods.add(createNestedClassBuildMethod(service, types)); return nestedClassMethods; } @@ -1556,6 +1556,43 @@ private static MethodDefinition createNestedClassUnaryMethodSettingsBuilderGette .build(); } + private static List createNestedClassSettingsBuilderGetterMethods( + Map nestedMethodSettingsMemberVarExprs) { + Reference operationCallSettingsBuilderRef = + ConcreteReference.withClazz(OperationCallSettings.Builder.class); + Function isOperationCallSettingsBuilderFn = + t -> + t.reference() + .copyAndSetGenerics(ImmutableList.of()) + .equals(operationCallSettingsBuilderRef); + List lroBetaAnnotations = + Arrays.asList( + AnnotationNode.builder() + .setType(STATIC_TYPES.get("BetaApi")) + .setDescription( + "The surface for use by generated code is not stable yet and may change in the" + + " future.") + .build()); + + List javaMethods = new ArrayList<>(); + for (Map.Entry settingsVarEntry : + nestedMethodSettingsMemberVarExprs.entrySet()) { + String varName = settingsVarEntry.getKey(); + VariableExpr settingsVarExpr = settingsVarEntry.getValue(); + boolean isOperationCallSettings = + isOperationCallSettingsBuilderFn.apply(settingsVarExpr.type()); + javaMethods.add( + MethodDefinition.builder() + .setAnnotations(isOperationCallSettings ? lroBetaAnnotations : ImmutableList.of()) + .setScope(ScopeNode.PUBLIC) + .setReturnType(settingsVarExpr.type()) + .setName(settingsVarExpr.variable().identifier().name()) + .setReturnExpr(settingsVarExpr) + .build()); + } + return javaMethods; + } + private static MethodDefinition createNestedClassBuildMethod( Service service, Map types) { TypeNode outerClassType = types.get(getThisClassName(service.name())); diff --git a/src/test/java/com/google/api/generator/gapic/composer/ServiceStubSettingsClassComposerTest.java b/src/test/java/com/google/api/generator/gapic/composer/ServiceStubSettingsClassComposerTest.java index 50f978ef1f..75cb1b3275 100644 --- a/src/test/java/com/google/api/generator/gapic/composer/ServiceStubSettingsClassComposerTest.java +++ b/src/test/java/com/google/api/generator/gapic/composer/ServiceStubSettingsClassComposerTest.java @@ -518,6 +518,52 @@ public void generateServiceClasses() { + " return unaryMethodSettingsBuilders;\n" + " }\n" + "\n" + + " public UnaryCallSettings.Builder echoSettings() {\n" + + " return echoSettings;\n" + + " }\n" + + "\n" + + " public ServerStreamingCallSettings.Builder" + + " expandSettings() {\n" + + " return expandSettings;\n" + + " }\n" + + "\n" + + " public StreamingCallSettings.Builder collectSettings()" + + " {\n" + + " return collectSettings;\n" + + " }\n" + + "\n" + + " public StreamingCallSettings.Builder chatSettings()" + + " {\n" + + " return chatSettings;\n" + + " }\n" + + "\n" + + " public StreamingCallSettings.Builder" + + " chatAgainSettings() {\n" + + " return chatAgainSettings;\n" + + " }\n" + + "\n" + + " public PagedCallSettings.Builder<\n" + + " PagedExpandRequest, PagedExpandResponse, PagedExpandPagedResponse>\n" + + " pagedExpandSettings() {\n" + + " return pagedExpandSettings;\n" + + " }\n" + + "\n" + + " public UnaryCallSettings.Builder waitSettings() {\n" + + " return waitSettings;\n" + + " }\n" + + "\n" + + " @BetaApi(\n" + + " \"The surface for use by generated code is not stable yet and may change in" + + " the future.\")\n" + + " public OperationCallSettings.Builder\n" + + " waitOperationSettings() {\n" + + " return waitOperationSettings;\n" + + " }\n" + + "\n" + + " public UnaryCallSettings.Builder blockSettings() {\n" + + " return blockSettings;\n" + + " }\n" + + "\n" + " @Override\n" + " public EchoStubSettings build() throws IOException {\n" + " return new EchoStubSettings(this);\n"