[
https://issues.apache.org/jira/browse/DRILL-5723?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=16151204#comment-16151204
]
ASF GitHub Bot commented on DRILL-5723:
---------------------------------------
Github user ilooner commented on a diff in the pull request:
https://github.com/apache/drill/pull/923#discussion_r136670944
--- Diff:
exec/java-exec/src/test/java/org/apache/drill/exec/server/rest/StatusResourcesTest.java
---
@@ -0,0 +1,80 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.apache.drill.exec.server.rest;
+
+import org.apache.drill.exec.ExecConstants;
+import org.apache.drill.exec.server.options.OptionValidator;
+import org.apache.drill.exec.server.options.TypeValidators;
+import org.apache.drill.test.ClientFixture;
+import org.apache.drill.test.ClusterFixture;
+import org.apache.drill.test.FixtureBuilder;
+import org.apache.drill.test.RestClientFixture;
+import org.junit.Assert;
+import org.junit.Test;
+
+import static org.apache.drill.test.TestConfigLinkage.MOCK_PROPERTY;
+import static
org.apache.drill.test.TestConfigLinkage.createMockPropValidator;
+
+public class StatusResourcesTest {
+ @Test
+ public void testRetrieveInternalOption() throws Exception {
+ TypeValidators.StringValidator stringValidator =
createMockPropValidator();
+
+ FixtureBuilder builder = ClusterFixture.builder().
+ configProperty(ExecConstants.HTTP_ENABLE, true).
+ configProperty(OptionValidator.OPTION_DEFAULTS_ROOT + MOCK_PROPERTY,
"a").
+ putValidator(MOCK_PROPERTY, stringValidator);
+
+ try (ClusterFixture cluster = builder.build();
+ ClientFixture client = cluster.clientFixture()) {
+ RestClientFixture restClientFixture = cluster.restClientFixture();
+
+ Assert.assertNull(restClientFixture.getStatusOption(MOCK_PROPERTY));
+ StatusResources.OptionWrapper option =
restClientFixture.getStatusInternalOption(MOCK_PROPERTY);
+ Assert.assertEquals("a", option.getValueAsString());
+
+ client.alterSystem(MOCK_PROPERTY, "c");
--- End diff --
I added a method that allows the addition of option validators at startup,
and those validators are passed to the SystemOption manager. I think this could
be enhanced using the OptionBuilder mechanism you described.
- I don't think it is useful to add options after starting a Drillbit, but
we could apply the OptionBuilder to add options at boot time.
- That should be possible. It was possible to add option validators to the
SystemOptionManager at boot time.
> Support System/Session Internal Options
> ---------------------------------------
>
> Key: DRILL-5723
> URL: https://issues.apache.org/jira/browse/DRILL-5723
> Project: Apache Drill
> Issue Type: New Feature
> Reporter: Timothy Farkas
> Assignee: Timothy Farkas
>
> This is a feature proposed by [~ben-zvi].
> Currently all the options are accessible by the user in sys.options. We would
> like to add internal options which can be altered, but are not visible in the
> sys.options table. These internal options could be seen by another alias
> select * from internal.options. The intention would be to put new options we
> weren't comfortable with exposing to the end user in this table.
> After the options and their corresponding features are considered stable they
> could be changed to appear in the sys.option table.
--
This message was sent by Atlassian JIRA
(v6.4.14#64029)