-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
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
[tellstick] Fixes a NoClassDefFoundError that caused the Tellstick addon to not work properly #9634
Changes from 1 commit
0a6a869
adb08c2
8e8c71c
a273149
4c35e5a
d059a45
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||||
---|---|---|---|---|---|---|---|---|
|
@@ -15,7 +15,7 @@ | |||||||
<name>openHAB Add-ons :: Bundles :: Tellstick Binding</name> | ||||||||
|
||||||||
<properties> | ||||||||
<bnd.importpackage>!com.luckycatlabs.*,!com.jcraft.jzlib.*,!org.apache.commons.cli.*,!org.eclipse.swt.*</bnd.importpackage> | ||||||||
<bnd.importpackage>!com.luckycatlabs.*,!com.jcraft.jzlib.*,!org.apache.commons.cli.*,!org.eclipse.swt.*,!javax.activation</bnd.importpackage> | ||||||||
<dep.noembedding>netty-transport-native-unix-common,netty-common,netty-transport,netty-transport-native-epoll,netty-buffer,netty-resolver,netty-codec,netty-codec-http,netty-handler</dep.noembedding> | ||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yea sure I can add the dependencies as bundles to the feature file like you wrote above. In fact I had it like that first but I removed it again because I did not see a need for it. Anyway, I have added them back now. I took the opportunity to change all the line endings in this and another xml file as it was causing some weird spotless errors for me and I noticed that no other addon had line endings like these files had. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. If you only add the tellstick bundle, it'll not work (the feature is not part of the tellstick bundle but compiled to a feature.xml with all the other bindings. If you decide to install a binding (via addons.cfg or UI) you are not installing the binding-bundle but the binding feature. This contains the bundle and (like in this case) also other bundles or other features). If you didn't manually install the additonal bundles, the tellstick bundle can't be resolved. That it why it needs to be added to the feature so karaf knows during installation of the tellstick binding it also needs to install the other bundles. Regarding you other questions: embedding is not the preferred way in an OSGi environment. At best we would have only proper OSGi bundles and don't need to embed bundles at all but add all bundles to the feature. Unfortunately we don't live in such a world. We have some bundles that are not OSGi bundles at all (e.g. javatellstick) or use improper versioning (e.g. incompatible API even if the minor version did not change). Therefore we decided to use embedding for bundles that are either not compatible, very unlikely will be used by other bindings or use different versions than other bindings. To automate that, we embed all bundles with the scope "compile". This scope is also needed for bnd to resolve the bundle in the IDE. That's why we add e.g. netty with scope "compile" to the pom and exclude it from embedding. Netty is used by different bindings (that's why we have the tp.netty feature to keep the used version inline for all binings). Hope that makes it more clear. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yes I think that makes it a bit clearer. So ok I have now added the three bundles to the dep.noembedding as well. Is this the preferred way to do it? For example if I want someone else to try out an addon before it is released they have to install the required bundles manually first like this? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's ok to do it that way. But: if it's an update to an existing binding, the preferred way would be to use the bundle-update command (e.g. for tellstick):
If the bundle is available for download, you can also use
That way only the bundle itself is updated and all dependency stay installed (unlike in case of deinstalling the binding, then the whole feature, so the bundle and it's dependencies if not needed by other bundles, are uninstalled). There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Ok, that is a good to know. |
||||||||
</properties> | ||||||||
|
||||||||
|
@@ -36,13 +36,13 @@ | |||||||
<dependency> | ||||||||
<groupId>org.asynchttpclient</groupId> | ||||||||
<artifactId>async-http-client</artifactId> | ||||||||
<version>2.0.19</version> | ||||||||
<version>2.10.4</version> | ||||||||
<scope>compile</scope> | ||||||||
</dependency> | ||||||||
<dependency> | ||||||||
<groupId>org.asynchttpclient</groupId> | ||||||||
<artifactId>async-http-client-netty-utils</artifactId> | ||||||||
<version>2.0.19</version> | ||||||||
<version>2.10.4</version> | ||||||||
<scope>compile</scope> | ||||||||
</dependency> | ||||||||
<dependency> | ||||||||
|
@@ -105,6 +105,24 @@ | |||||||
<version>4.1.42.Final</version> | ||||||||
<scope>compile</scope> | ||||||||
</dependency> | ||||||||
<dependency> | ||||||||
<groupId>io.netty</groupId> | ||||||||
<artifactId>netty-transport-native-kqueue</artifactId> | ||||||||
<version>4.1.42.Final</version> | ||||||||
<scope>compile</scope> | ||||||||
</dependency> | ||||||||
<dependency> | ||||||||
<groupId>io.netty</groupId> | ||||||||
<artifactId>netty-handler-proxy</artifactId> | ||||||||
<version>4.1.42.Final</version> | ||||||||
<scope>compile</scope> | ||||||||
</dependency> | ||||||||
<dependency> | ||||||||
<groupId>io.netty</groupId> | ||||||||
<artifactId>netty-codec-socks</artifactId> | ||||||||
<version>4.1.42.Final</version> | ||||||||
<scope>compile</scope> | ||||||||
</dependency> | ||||||||
Comment on lines
+108
to
+125
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why are you including these dependencies in the binding jar if they are already included in the runtime environment? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. These are new dependencies required by the new version of async-http-client. I am quite sure that it will work as well if we add these three dependencies, that I need, to the openhab.tp-netty feature instead but I guess that that will impact all other addons that rely on that feature and it would require a change in the openhab-core. That works for me but as I am unsure of the impact of such a change I think someone with a better knowledge of the build/feature/dependency setup should make that call. |
||||||||
<dependency> | ||||||||
<groupId>org.reactivestreams</groupId> | ||||||||
<artifactId>reactive-streams</artifactId> | ||||||||
|
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.
This is not needed if I compile locally?
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 it is not needed when compiling but during runtime.
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.
If it's needed during runtime you must not exclude it. Instead you need to add the required dependency. But I believe that is already present in the target platform anyway, otherwise the karaf plugin should fail to resolve the feature.
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 I meant that the change is not needed to be able to compile but it is there to sort out a runtime issue. So in fact it is the opposite, the new version of async-http-client has javax.activation as a transitive dependency but this addon does not seem to use those parts of the async-http-client library so that is why I excluded javax.activation rather than adding the dependency for it.
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.
Maybe. Fine if it works. The other option would be to add
to the feature. That is activation API we use in other bundles. But fine with me if it works with the exclusion. Up to you.
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.
Yea maybe that is a nicer solution even though it is not used.
I added that bundle as well and removed the exclude.