-
Notifications
You must be signed in to change notification settings - Fork 145
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
Reduce Win32 FontRegistries visibility and move tests inside fragment #1203
Reduce Win32 FontRegistries visibility and move tests inside fragment #1203
Conversation
f69be01
to
faebc93
Compare
@@ -35,8 +35,14 @@ source.. = \ | |||
../../bundles/org.eclipse.swt/Eclipse SWT Browser/win32,\ | |||
../../bundles/org.eclipse.swt/Eclipse SWT OpenGL/win32,\ | |||
../../bundles/org.eclipse.swt/Eclipse SWT OpenGL/common | |||
source.test = \ |
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.
Test folders should usually not be part of the source.xxx
/ bin.xxx
of PDE...
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 I am not yet sure how to properly make Tycho compile the test classes. With this configuration, Tycho properly generates test classes in a separate output folder to be used for executing the maven-surefire-plugin. What would be the proper approach to achieve 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.
it will jsut work without that, as it is configured in the .classpath
already.
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.
That's correct. Only the .classpath configuration is currently not considered because the .classpath file is not considered due to being a linked resource.
|
||
pom.model.property.os=win32 | ||
pom.model.property.ws=win32 | ||
pom.model.property.arch=x86_64 | ||
|
||
additional.bundles = junit-jupiter-api,\ |
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.
For test folder use a JUNIT Classpath container instead of additional bundles (what server a completely different purpose)
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 wanted to ask you exactly what you think is the proper approach here, as additional.bundles were only my first attempt to get things running. I have added this as a means to make Tycho have the JUnit dependencies at compile-/test-time. I've already specified a JUnit classpath container in the .classpath
, but that's not considered for the Tycho build, is it? At least Tycho complains about missing JUnit dependencies when compiling the test sources. Probably it would be better to add the JUnit dependency directly to the Maven build?
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've already specified a JUnit classpath container in the .classpath, but that's not considered for the Tycho build, is it?
This is supported since Tycho 2.4
At least Tycho complains about missing JUnit dependencies
Maybe a bug or misconfiguration, at least we have some test for this here that should prove it works.
Probably it would be better to add the JUnit dependency directly to the Maven build?
While it maybe works, the purpose of Tycho is to not need special maven configuration so it might be a good opportunity to find out why it does not work and either improve Tycho or the documentation (sadly it misses the part about eclipse setup currently).
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.
Then something does obviously not work here as expected:
- Tycho does not consider the test source folder specified via the
.classpath
. If I understand correctly, it should automatically use those test source folder to compile test classes. - When specifying the test source and output folder manually in the build.properties, Tycho complain about missing JUnit dependencies when compiling them.
I guess that both the specification of test source and output folder in the build.properites as well as the additional specification of JUnit dependencies relate to the same root cause, due to which the information from the .classpath
file are not considered correctly. I will try to figure out what is special in the SWT setup compared to the Tycho integration tests for that behavior.
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.
it might be because classpath is a linked file, can you try to copy the file as a regular one into the project? I recently added support for linked files, but that for sure not respected everywhere at the moment.
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.
Thank you, @laeubi! The linked files are actually the problem here. It affects both the linked .classpath
file as well as the linked test source folder.
- When replacing the linked
.classpath
with the same file directly placed in the project, Tycho properly considers the test source folder specified in the.classpath
file. Then it only complains that it does not find that (linked) folder:
[WARNING] Source directory C:\dev\eclipse\platform-only\git\eclipse.platform.swt\binaries\org.eclipse.swt.win32.win32.x86_64\Eclipse SWT Tests\win32 does not exist
- When also replacing the linked source test folder with the same folder directly placed in the project, test source files are compiled correctly and tests are executed.
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.
okay then this needs some adjustment in Tycho first, I'll try to take a look. As always if one want to
provide an integration-test to demonstrate the issue that would be helpful.
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 have already created an according integration test (on https://github.com/HeikoKlare/tycho/tree/issue_3803_reproducer) and will provide a describing issue and a PR with that test to the Tycho project tomorrow.
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.
Tycho issue is now documented along with a reproducer PR: eclipse-tycho/tycho#3803
faebc93
to
8038f74
Compare
0afd86e
to
0e689a8
Compare
I have restructured the custom configuration for running the tests via Tycho as a temporary solution until eclipse-tycho/tycho#3803 has been addressed. The solution has the following main properties to make it easy to replace with an in-build Tycho solution once available:
I consists of the following additions:
I have added comments to all additions that are part of the temporary solution to easily remove them later on. @laeubi What do you think about this temporary solution? Since the colleagues working on Windows HiDPI support have a rather urgent demand for being able to provide this kind of tests, I would like to integrate this (or some other kind of temporary solution) to not depend on when the Tycho feature can/will be realized. For whomever is wondering that it might make sense to directly start with JUnit 5 instead of JUnit 4: I want to keep this initial restructuring PR as simple as possible (and the moved tests are JUnit 4) and will provide a follow-up that migrates to JUnit 5. |
0e689a8
to
f7aa1c5
Compare
@HeikoKlare if it works I won't object in general, but maybe it also works for your college to simply not branch from master but from your brach and add items on top of it? Then it should work to already develop / test things and later on only needs a rebase on master if we (hopefully soon) have the final solution. |
In general, I would prefer that over having an intermediate solution in master, However, the tests come together with several functional additions. These functional additions depend on each other and we want / need to merge them into master in small increments to ensure continuous validation and minimize the risk of regressions. Merging all of them in a separate branch would lead to a large merge into master afterwards with a too high risk of producing regressions. |
} | ||
|
||
private static boolean isFittingOS() { | ||
return System.getProperty("os.name").toLowerCase().startsWith("win"); |
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 somehow remmber we already have a way in SWT to determine the platform.
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.
org.eclipse.swt.tests.junit.SwtTestUtil.isWindows
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, there are at least two ways to determine the platform, but unfortunately none of them is applicable here:
- The platform for which the currently accessed fragment as stored in
Platform.PLATFORM
. At usual runtime, you have the fragment matching your OS loaded (as defined by the platform filter of the fragment), so you can use this to determine the platform you are running. When executing these tests, however, you will always access thePlatform
class from the fragment that you are currently processing, soPlatform.PLATFORM
will always be "win32" in this case, even if you are running on Linux or MacOS. - The
SwtTestUtil
(as referred to by Ed). But they are placed in the downstream test plug-in and not in the SWT plug-in itself.
But since I have moved this util class to the same package as the Library
class to retrieve the system architecture from the Library
class, I can now also retrieve the OS from that class (which does the same as the SwtTestUtil
). I have adapted this method accordingly in 91a97ca.
f7aa1c5
to
91a97ca
Compare
91a97ca
to
b256ce7
Compare
Thanks to @laeubi's fast improvement for Tycho, the tests inside the SWT fragments now run properly without custom Maven configuration. I was able to update / simplify this PR accordingly in b256ce7. So we can merge this without adding any temporary solution. The only thing remaining is that the test source folder linked in the project description cannot use the |
The classes DefaultSWTFontRegistry and ScalingSWTFontRegistry are currently public only to make them testable from a test bundle. There is currently no pre-configured way to implement unit tests for classes that are not directly accessible via public API. With this change, the SWT Win32 fragments are extended by a configuration for providing fragment-internal unit tests executed with plain Maven surefire, which can access the classes under test even with reduced visibility. Due to current limitation in Tycho, an according temporary extension to the Maven configuration for the binaries projects is made. This configuration is applied to the tests for the DefaultSWTFontRegistry and ScalingSWTFontRegistry, such that their visibilities can properly be reduced to package visibility.
b256ce7
to
0c56201
Compare
Just as a quick remark without knowing if this has already been considered: The 'PDE-way' to achieve this is to make the test a fragment of the tested plugin and place the test in the same package. Or is this not possible due to the special structure of the SWT bundles/fragments? |
A fragment can't have another fragment as a host. |
Of course, but it could just use |
We have discussed different options on how to realize such tests in a separate discussion thread (eclipse-platform/.github#203). Seems like I forgot to reference the discussion in this PR.
The Windows tests (as well as potentially other OS tests or even common tests) can/will be at two places:
|
Sorry I have missed that (I'm not subscribed for all events in the platform and platform.ui repo). |
While this technically works, I'm not sure the tooling (IDE + Build) is really prepared for that, lets assume we Have |
I tried this as an alternative to this PR with the initial, temporary solution (when Tycho support was linked .classpath files was missing) but did not find a proper way to enable the test fragment to access classes of the Windows fragment. I did not invest too much time but it did not feel as good as the solution of having the unit tests directly within the fragments anyway. |
The classes DefaultSWTFontRegistry and ScalingSWTFontRegistry are currently public only to make them testable from a test bundle. There is currently no pre-configured way to implement unit tests for classes that are not directly accessible via public API.
With this change, the SWT Win32 fragments are extended by a configuration for providing fragment-internal unit tests executed with plain Maven surefire, which can access the classes under test even with reduced visibility. Due to current limitations in Tycho (see eclipse-tycho/tycho#3803), an according temporary extension to the Maven configuration for the binaries projects is made. This configuration is applied to the tests for the DefaultSWTFontRegistry and ScalingSWTFontRegistry, such that their visibilities can properly be reduced to package visibility.