-
Notifications
You must be signed in to change notification settings - Fork 32
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
H5P CLI tool may cause confusion by ignoring library versions #55
Comments
Hey, Oliver. As a temporary workaround until this is fixed you can setup specific versions of libraries by running something like |
I am not using the H5P CLI tool for development (yet) :-D |
#58 fixes setup command when fetching specific versions. That being said, because some h5p libraries are missing tags for some release versions, changing the default setup command to make it strict in terms of what versions are pulled would sometimes make it impossible to complete the setup. For example, h5p-font-awesome is missing the “4.5.6” tag although currently sitting at version 4.5.6. I've updated the commands.md file to describe the default behavior of the setup function and how it uses master branches when no specific version is requested. |
@devland I am well aware that this is an organizational problem of missing tags (https://github.com/boyum/pack-h5p-action is suffering from the same issue, though there it seems even more troublesome as it is supposed to build packages for production). It might be addressed with a github action that automatically tag a version once the library version changes, but that's up to the maintainer, of course. That's why I mentioned the option to at least warn the developer that the version referenced by the content type does not match the version on the master branch - or to fail as an H5P integration would while requiring attention by the developer to fix this himself/herself but not violating the H5P specification. |
I agree with @otacke. We should at least check and warn the user if we have set up an incorrect version. Should we also consider using the stable brach by default if it exists? This would make sense if we assume that we are mostly not fetching libraries to make changes to them but fetching them as dependencies for the code we are making changes to... |
It feels similar to what happens if you install a library on Linux and some dependency cannot be resolved. You will be presented with options (e.g. keep the existing version, change the repository source, ignore, ...) Similarly, if the master branch does not hold the version that is referenced, one could check what options exist depending on what the repository supplies and then display a dialog for the developer to choose from. Something like:
T) Would require to check the repository for common tag name patterns (something along the lines of One could introduce a flag for the preferred resolution order, e.g. I know, this means some effort ... |
Just ran into that trap myself. H5P CLI fetched Interactive Video 1.26.32 from the master branch. The release version is 1.26.30. Shared some demo content that would not run on Lumi. Why? Lumi still uses a core version < 1.26 which is fine for IV 1.26.30, but not for IV 1.26.32. Had to waste some time to figure out what the problem actually was. :-( Yes, Lumi needs to upgrade the H5P core version, problem solved. Still, as this issue's title states: "H5P CLI tool may cause confusion by ignoring library versions". And just wondering: Shouldn't h5p/h5p-interactive-video@6f1fd34 (changing the required version of H5P core) have been accompanied with a bump of the minor version of Interactive Video to 1.27.0? |
Hello @devland Although, they do tag different versions. So ended up using your tip : But this results in an unexpected behavior (it still ends up pulling latest afaik). Below the output of the command :
Then proceeds installing the library on the latest version.
|
When setting up libraries and fetching dependencies, the H5P CLI tool may cause confusion.
For instance,
H5P.Column
currently referencesH5P.Agamotto 1.5
as a soft dependency insemantics.json
. The H5P CLI tool will fetch the master branch ofH5P.Agamotto
which already holds the 1.6 version, but it will neither notify the developer about that discrepancy (and suggest taking care of this by looking for the correct tag/commit) nor fail as a particular version of a library cannot be loaded like regular H5P integrations would. The H5P CLI tool will treatH5P.Agamotto 1.6
as if it wasH5P.Agamotto 1.5
.That will work in many cases and one will not even notice anything, but it can cause confusion at least:
The text was updated successfully, but these errors were encountered: