This document can help you to fix the common problems encountered while contributing to TEAMMATES. Note that some of the screenshots might be outdated, but the instructions will remain the same and all necessary modifications will be explained.
-
ERROR: After downloading and installing Google Cloud SDK, running any
gcloud
command results ingcloud: command not found
or alike.REASON: You did not choose to update the
PATH
variable when installing the SDK.SOLUTION: You can re-run the install command again without any side effect. Make sure to choose to update the
PATH
variable this time. Alternatively, you can use other appropriate methods to update yourPATH
variable to include the/bin
sub-folder of the SDK folder.
To verify this, try running anygcloud
command and it should now give you access to the SDK. -
ERROR (on Windows): Dev server launched by Eclipse keeps running even after closing Eclipse. After restarting Eclipse, you will be able to relaunch dev server on the same port but requests will be received by the previous server instance.
REASON: If Eclipse crashes while dev server is running inside Eclipse, the server might keep running even after Eclipse is closed.
SOLUTION: Go to Windows Task Manager and kill processes named
javaw.exe
. -
ERROR: Eclipse complains "file out of sync".
SOLUTION: "Refresh" the project in Eclipse.
-
ERROR: Eclipse complains "There are no JREs installed in the workplace that are strictly compatible with this environment.".
REASON: Eclipse may be using an incompatible version of the JRE Library (with respect to TEAMMATES) for the current JRE definition. System Library for JRE should be set to the workspace default, after an appropriate JRE definition has been added (covered in existing point#2 of the troubleshooting section).
SOLUTION: Right-click on project → Properties → Java Build Path → "Libraries" tab → Select JRE System Library from the list → Edit… → Select and mark radio button for "Workspace default JRE".
-
ERROR: Eclipse complains "NewClass cannot be resolved to a type", "The import some.package.NewClass cannot be resolved", or "The method someMethod() from the type ExistingClass refers to the missing type NewClass" after syncing with
master
branch.SOLUTION: This is likely because the dependencies have changed. Right click on the project in the Project Explorer and select
Gradle → Refresh Gradle Project
for the changes to be reflected. -
ERROR: Some characters are displayed incorrectly in the browser. For example,
Charlés's
is displayed asCharlés
.REASON: Page encoding is not set to UTF-8.
SOLUTION: In Eclipse, go to
Window
→Preferences
→Resources
→ change theText file encoding
setting fromDefault
toOther: UTF-8
. If this does not fix the error, you can try the methods in this link.
The default place for the TestNG tab is alongside the Console tab.
Here is a better place for it. Just drag the tab and drop it alongside the Project Explorer tab.
Our automated Browser tests compare generated Web pages with expected pages (these are in the src/test/resources/pages
folder). Such test cases fails when the expected page does not match the actual page. To see the diff between actual and expected, double click the error message in the TestNG tab.
Here is an example (use the zoom feature of the Browser to see details of the screenshot):
Note that you can ignore the following differences reported by Eclipse diff tool. Those are not the cause of the test failure.
Expected | Actual | Explanation |
---|---|---|
<expected></expected> |
<actual></actual> |
These are inserted by the test code for easier reference, after the comparison has been done. |
Furthermore, you might see tags such as ${test.student1}
and ${version}
in some of the expected files (e.g. studentHomeHTML.html
) if you open them in Eclipse. The test code will replace those tags with correct values before performing the comparison. For example, ${version}
will be replaced by something like 6.0.0
.
-
ERROR: Encountered
java.net.ConnectException: Connection refused
when running some tests.SOLUTION: Ensure that your dev server is started prior to running those tests.
-
ERROR: Encountered
org.openqa.selenium.WebDriverException: Unable to bind to locking port 7054 within 45000 ms
when running tests with Browser.SOLUTION: Ensure compatible version of Firefox is installed as specified under Development process document.
-
ERROR: Tests fail randomly during dev server testing.
SOLUTION: Make sure there is only one dev server running. Eclipse will happily allow you to start multiple dev servers.
-
ERROR: Test failure message encountered when running full test suite: "Selenium cannot find Firefox binary in PATH".
REASON 1: Path to Firefox executable on local machine is incorrect.
SOLUTION 1 (on Windows): Specify the correct folder in system PATH variable.
Open Windows Explorer → Right-click on Computer → Advanced System Settings → "Advanced" tab → Environment Variables… → Select "PATH" from the list → Add directory of "Mozilla Firefox" folder to "Variable value" field.
REASON 2: Incorrect custom path in
test.firefox.path
.SOLUTION 2: Make sure that the path is set correctly following the example from
test.template.properties
. -
ERROR: A handful of failed test cases (< 10).
SOLUTION: Re-run the failed tests with TestNG, all test cases should pass eventually (it may take a few runs). If there are tests that persistently fail and not addressed in other parts of this guide, you may request for help in the issue tracker.
-
ERROR: Tests fail due to accented characters.
SOLUTION: Ensure that the text file encoding for your Eclipse workspace has been set to
UTF-8
as specified under Setting up guide. -
ERROR: Error message in the console about "incorrect date format".
SOLUTION: Ensure the date format of your computer matches the below. For Windows, this link may be useful.
-
ERROR:
InstructorCourseDetailsPageUiTest
fails in production server due to Gmail's access restriction (e.gjavax.mail.AuthenticationFailedException
)SOLUTION: "Allow access for less secure apps" for the accounts used in that particular test. As doing so will leave the accounts more vulnerable to security issues, it is strongly recommended that the access is revoked after the test passes.
-
ERROR (on Linux):
java.io.IOException: Directory "/tmpfiles" could not be created
.SOLUTION: Add
-Djava.io.tmpdir=/path/to/teammates/tmp
for the tests' run configurations. The "tmp" folder in the specified directory needs to be created before running the tests.
If none of the items in this guide helps with the problem you face, you can post in the issue tracker to request for help. Remember to supply as much relevant information as possible when requestng for help, e.g.:
- Step in the setting up guide that you are in (if you are setting up the project), or which tests are failing (if you are resolving test failures)
- Error messages shown on the console (or from the TestNG tab if resolving test failures)
- What measures you have taken to address the problem
- Operating system, JDK version, Eclipse version, Firefox version (where applicable)
- Screenshots (if any)