-
Notifications
You must be signed in to change notification settings - Fork 864
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
Draft for reading configuration from config files #1722
base: master
Are you sure you want to change the base?
Conversation
I think that this approach makes sense in that it lets configuration come from the environment, system properties, file, or classpath. I think that's a good thing and that we should follow this pattern. For actually checking the setting of various flags, however, I think that the config class should parse all this input and set boolean (or enum) values that can be checked directly, rather than relying on a hash lookup. I think that can give us two advantages:
|
I think I can implement this next week or so... |
If you're looking for the kinds of debug flags I'd like to potentially replace with a real debugging mechanism, I would look at these:
And as for feature flags, the first one IMO should be for the reflect and proxy support that's currently languishing in a PR by @rbri |
Unfortunately, I didn't have as much time as I thought, but I wanted to update the draft before Christmas of how I want to do it now. The idea is, to check all sources (classpath, configfile, system-properties, env - the last one wins) for the settings and parse them immediately in the correct datatype. When a variable is bound to the property @gbrail I hope, this goes in the right direction... Unfortunately (or fortunately) I won't be able to continue until next year due to vacation. :) |
So, I found some time to update this PR. What do we have now The
When checking for a value, There is a helper class
I tried that, but did not like the idea to add configs from different packages in one class:
Other findings, I identified:
it would be good, if I get some feedback, if this goes in a way we want. @gbrail FYI |
@gbrail ping... Did you find already time to give some feedback? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this is good progress, and minus the attached minor comments, I think that this is the right implementation.
I also want to know how we can test this -- there are a lot of options with properties files, system properties, environment variables, and a service loader.
I really think that we should go forward with this, but only if we can put in some way to exercise more of this codebase in our test suite.
if (ret != null) { | ||
Class<T> enumType = (Class<T>) defaultValue.getClass(); | ||
// We assume, that enums all are in UPPERCASES | ||
return Enum.valueOf(enumType, ret.toString().toUpperCase(Locale.ROOT)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we catch "IllegalArgumentException" in case the input value is not valid and return the default in that case?
if (ret instanceof Boolean) { | ||
return (Boolean) ret; | ||
} else { | ||
return "1".equals(ret) || "true".equals(ret); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wonder if you'd consider numeric values other than 1 as "true," and doing a case-insensitive comparison to "true"
props.load(new InputStreamReader(in, StandardCharsets.UTF_8)); | ||
addConfig(props); | ||
} catch (IOException e) { | ||
System.err.println( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't love that we "println" anywhere, but I don't see that we have a choice in this case. But if it happens, it'll be buried in someone's big log file and they won't know what it means -- should we consider adding "Rhino:" or something to identify this message so that people can know why it's appearing?
props.load(new InputStreamReader(in, StandardCharsets.UTF_8)); | ||
addConfig(props); | ||
} catch (IOException e) { | ||
System.err.println( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same here -- we should add "Rhino" or something to this.
This could be a first draft for #1720