-
Notifications
You must be signed in to change notification settings - Fork 111
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
[RSDK-9498] Search for meta.json File in Top Level of Online Module #4689
base: main
Are you sure you want to change the base?
Conversation
config/module.go
Outdated
@@ -282,7 +282,13 @@ func (m *Module) FirstRun( | |||
logger.Debug("no first run script specified, skipping first run") | |||
return nil | |||
} | |||
relFirstRunPath, err := utils.SafeJoinDir(unpackedModDir, meta.FirstRun) | |||
var firstRunTopLevelDir string |
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.
Before, meta.FirstRun
was used relative to the directory specified by unpackedModDir
. In the case that the module has a type
of registry
, this would just be the parent directory of the module's entry point executable - not necessarily the top level of its directory. Here, I've changed it so that if moduleWorkingDirectory
is not the empty string (which is equivalent to saying that the module's type
is registry
and the VIAM_ROOT_MODULE environment variable has been set), then the module's top level directory is used to find and execute the specified "first run" script.
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.
why not just have moduleWorkingDirectory get returned all the time?
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.
Good point, this will clean up the code a bit.
config/module.go
Outdated
return meta, "", err | ||
} | ||
|
||
if m.Type == ModuleTypeRegistry { |
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.
Before, this function would automatically return an error and no meta information when m.Type == ModuleTypeRegistry
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 feel like this case should be at the top then, and also only check in the moduleWorkingDirectory
.
Since if m.Type == ModuleTypeRegistry then this will go through the !localNonTarball branch automatically
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.
have some comments, and we should have at least 1 test for this
config/module.go
Outdated
return nil, err | ||
} | ||
_, err = os.Stat(metaPath) | ||
if err == nil { |
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.
have the conditional be err != nil so we can early return
config/module.go
Outdated
@@ -381,38 +387,75 @@ func (m *Module) FirstRun( | |||
// 1. if there is a meta.json in the exe dir, use that, except in local non-tarball case. |
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.
the comment should be rewritten to reflect the current state of things.
@@ -381,38 +387,75 @@ func (m *Module) FirstRun( | |||
// 1. if there is a meta.json in the exe dir, use that, except in local non-tarball case. | |||
// 2. if this is a local tarball and there's a meta.json next to the tarball, use that. | |||
// Note: the working directory must be the unpacked tarball directory or local exec directory. | |||
func (m Module) getJSONManifest(unpackedModDir string) (*JSONManifest, error) { | |||
func (m Module) getJSONManifest(unpackedModDir string, env map[string]string) (*JSONManifest, string, error) { |
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.
would like to see a test for this
@@ -267,7 +267,7 @@ func (m *Module) FirstRun( | |||
|
|||
// Load the module's meta.json. If it doesn't exist DEBUG log and exit quietly. | |||
// For all other errors WARN log and exit. | |||
meta, err := m.getJSONManifest(unpackedModDir) | |||
meta, moduleWorkingDirectory, err := m.getJSONManifest(unpackedModDir, env) |
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.
want to see an integration test around this whole function
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.
Do you mean around getJSONManifest()
? or around the FirstRun()
which calls getJSONManifest()
?
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.
around FirstRun() at the very least, would recommend trying to unit test getJSONManifest() as well
config/module.go
Outdated
return meta, "", err | ||
} | ||
|
||
if m.Type == ModuleTypeRegistry { |
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 feel like this case should be at the top then, and also only check in the moduleWorkingDirectory
.
Since if m.Type == ModuleTypeRegistry then this will go through the !localNonTarball branch automatically
config/module.go
Outdated
@@ -282,7 +282,13 @@ func (m *Module) FirstRun( | |||
logger.Debug("no first run script specified, skipping first run") | |||
return nil | |||
} | |||
relFirstRunPath, err := utils.SafeJoinDir(unpackedModDir, meta.FirstRun) | |||
var firstRunTopLevelDir string |
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.
why not just have moduleWorkingDirectory get returned all the time?
config/module.go
Outdated
if !ok { | ||
return nil, "", errors.Errorf("VIAM_MODULE_ROOT not set. Failed to find meta.json in executable directory %s", unpackedModDir) | ||
} | ||
return nil, "", errors.Errorf("failed to find meta.json. Searched in executable directory %s and path set by VIAM_MODULE_ROOT %s", |
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.
can we ever reach this line?
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 yes. As this function is currently written, we only search for the meta.json file in two locations 1) the top level directory of the online module and 2) in the same sub-directory of the module's executable. If the meta.json lives anywhere else, it won't be found - even if the VIAM_MODULE_ROOT env. variable is set. I could be wrong re: how modules are unpacked/sourced/retrieved.
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 ask because I'm pretty sure I saw both terminal ok
and !ok
cases at the time
also adding @benjirewis |
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.
Agree wrt more tests. Looks pretty good, though.
// 2. if this is a local tarball and there's a meta.json next to the tarball, use that. | ||
// TODO(RSDK-9498): write test(s) | ||
// getJSONManifest returns a loaded meta.json from one of three sources (in order of precedence): | ||
// 1. if this is an online module and there is a meta.json in its top level directory, use that. |
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.
What's an "online module"? A registry module? Why would we only allow meta.json in top-level directory for registry modules and not local modules? It's possible the answer to that last question is "local modules never have meta.jsons," if so, apologies for misunderstanding.
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.
Yes sorry online module is the same thing as a registry module. The ticket only calls for searching in the top level of the module if it's a registry module. I'm not 100% sure why this is the case, but I think it's because the top level of the module is only found/accessed through the "VIAM_MODULE_ROOT" environment variable, which is only guaranteed to be set when using a registry module (as opposed to a local one).
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.
Seems fair to me.
|
||
// case 1: online | ||
if online { | ||
moduleWorkingDirectory, ok = env["VIAM_MODULE_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.
[nit] Is there a constant for this string?
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.
Unfortunately not atm :/, it's used throughout the code base just as a standalone string the way I do^. Should I overhaul?
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.
No need to overhaul if there's no existing constant. We should have constants for all Viam env vars, but that's out of scope for this PR.
Search for a registry module's meta.json file in the top level of the module and in the parent directory of its executable entry point.
Testing
Running the robot linked in the Jira ticket no longer outputs the WARN log listed.
first_run.sh
is successfully sourced and executed, and adist.first_run_succeeded
file is created.Note: This has only been tested with a registry module, not a local module.