Skip to content

Commit

Permalink
Logging: No longer mark log messages from nvda.pyw as coming from ext…
Browse files Browse the repository at this point in the history
…ernal code when running from sources (nvaccess#13827)

Summary of the issue:
When starting NVDA from sources messages logged from nvda.pyw are shown as external. Example message:

INFO - external:__main__ (17:20:02.477) - MainThread (4316):
Starting NVDA version source-master-b817b03

This is clearly wrong. The problem is caused by the trailing backslash added in bat scripts (%~dp0 is already terminated with one and adding a second backslash causes logHandler.isPathExternalToNVDA to think that the path is external).

Description of user facing changes
Log messages from nvda.pyw are no longer marked as external.

Description of development approach
All usages of %~dp0 are inspected and trailing backslash is no longer added to the paths. To make logHandler.isPathExternalToNVDA more resilient to invalid paths the path is normalized before checking if it is the same as sys.path.
  • Loading branch information
lukaszgo1 authored Jun 27, 2022
1 parent ac7215b commit ebb05fe
Show file tree
Hide file tree
Showing 10 changed files with 66 additions and 14 deletions.
12 changes: 9 additions & 3 deletions runlint.bat
Original file line number Diff line number Diff line change
@@ -1,9 +1,15 @@
@echo off
rem runlint <base commit> [<output file>]
rem Lints any changes after base commit up to and including current HEAD, plus any uncommitted changes.
call "%~dp0\venvUtils\venvCmd.bat" py "%~dp0\tests\lint\genDiff.py" %1 "%~dp0\tests\lint\_lint.diff"
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%\venvUtils
set lintFilesPath=%here%\tests\lint

call "%scriptsDir%\venvCmd.bat" py "%lintFilesPath%\genDiff.py" %1 "%lintFilesPath%\_lint.diff"
if ERRORLEVEL 1 exit /b %ERRORLEVEL%
set flake8Args=--diff --config="%~dp0\tests\lint\flake8.ini"
set flake8Args=--diff --config="%lintFilesPath%\flake8.ini"
if "%2" NEQ "" set flake8Args=%flake8Args% --tee --output-file=%2
type "%~dp0\tests\lint\_lint.diff" | call "%~dp0\venvUtils\venvCmd.bat" py -Xutf8 -m flake8 %flake8Args%
type "%lintFilesPath%\_lint.diff" | call "%scriptsDir%\venvCmd.bat" py -Xutf8 -m flake8 %flake8Args%

8 changes: 7 additions & 1 deletion runnvda.bat
Original file line number Diff line number Diff line change
@@ -1,2 +1,8 @@
@echo off
call "%~dp0\venvUtils\venvCmd.bat" start pyw "%~dp0\source\nvda.pyw" %*
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%\venvUtils
set sourceDirPath=%here%\source

call "%scriptsDir%\venvCmd.bat" start pyw "%sourceDirPath%\nvda.pyw" %*
8 changes: 7 additions & 1 deletion runsettingsdiff.bat
Original file line number Diff line number Diff line change
@@ -1,2 +1,8 @@
@echo off
call "%~dp0\venvUtils\venvCmd.bat" py -m robot --argumentfile "%~dp0\tests\system\guiDiff.robot" %* "%~dp0\tests\system\robot"
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%\venvUtils
set systemTestsPath=%here%\tests\system

call "%scriptsDir%\venvCmd.bat" py -m robot --argumentfile "%systemTestsPath%\guiDiff.robot" %* "%systemTestsPath%\robot"
7 changes: 6 additions & 1 deletion runsystemtests.bat
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
@echo off
call "%~dp0\venvUtils\venvCmd.bat" py -m robot --argumentfile "%~dp0\tests\system\robotArgs.robot" %* "%~dp0\tests\system\robot"
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%\venvUtils
set systemTestsPath=%here%\tests\system

call "%scriptsDir%\venvCmd.bat" py -m robot --argumentfile "%systemTestsPath%\robotArgs.robot" %* "%systemTestsPath%\robot"
8 changes: 7 additions & 1 deletion rununittests.bat
Original file line number Diff line number Diff line change
@@ -1,2 +1,8 @@
@echo off
call "%~dp0\venvUtils\venvCmd.bat" py -m nose -sv --traverse-namespace -w "%~dp0\tests\unit" %*
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%\venvUtils
set unitTestsPath=%here%\tests\unit

call "%scriptsDir%\venvCmd.bat" py -m nose -sv --traverse-namespace -w "%unitTestsPath%" %*
6 changes: 5 additions & 1 deletion scons.bat
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
@echo off
rem Executes SScons within the NVDA build system's Python virtual environment.
call "%~dp0\venvUtils\venvCmd.bat" py -m SCons %*
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%\venvUtils
call "%scriptsDir%\venvCmd.bat" py -m SCons %*
9 changes: 7 additions & 2 deletions source/logHandler.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,9 +30,14 @@
EVENT_E_ALL_SUBSCRIBERS_FAILED = -2147220991
LOAD_WITH_ALTERED_SEARCH_PATH=0x8

def isPathExternalToNVDA(path):

def isPathExternalToNVDA(path: str) -> bool:
""" Checks if the given path is external to NVDA (I.e. not pointing to built-in code). """
if path[0] != "<" and os.path.isabs(path) and not path.startswith(sys.path[0] + "\\"):
if(
path[0] != "<"
and os.path.isabs(path)
and not os.path.normpath(path).startswith(sys.path[0] + "\\")
):
# This module is external because:
# the code comes from a file (fn doesn't begin with "<");
# it has an absolute file path (code bundled in binary builds reports relative paths); and
Expand Down
9 changes: 7 additions & 2 deletions venvUtils/ensureAndActivate.bat
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,14 @@
rem this script ensures the NVDA build system Python virtual environment is created and up to date,
rem and then activates it.
rem This is an internal script and should not be used directly.
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%
set venvLocation=%here%\..\.venv

rem Ensure the environment is created and up to date
py -3.7-32 "%~dp0\ensureVenv.py"
py -3.7-32 "%scriptsDir%\ensureVenv.py"
if ERRORLEVEL 1 goto :EOF

rem Set the necessary environment variables to have Python use this virtual environment.
Expand All @@ -18,7 +23,7 @@ rem set the VIRTUAL_ENV variable instructing Python to use a virtual environment
rem py.exe will honor VIRTUAL_ENV and launch the python.exe that it finds in %VIRTUAL_ENV%\scripts.
rem %VIRTUAL_ENV%\scripts\python.exe will find pyvenv.cfg in its parent directory,
rem which is actually what then causes Python to use the site-packages found in this virtual environment.
set VIRTUAL_ENV=%~dp0..\.venv
set VIRTUAL_ENV=%venvLocation%
rem Add the virtual environment's scripts directory to the path
set PATH=%VIRTUAL_ENV%\scripts;%PATH%
rem Set an NVDA-specific variable to identify this official NVDA virtual environment from other 3rd party ones
Expand Down
7 changes: 6 additions & 1 deletion venvUtils/exportPackageList.bat
Original file line number Diff line number Diff line change
@@ -1,7 +1,12 @@
@echo off
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%

setlocal
if "%VIRTUAL_ENV%" == "" (
call "%~dp0\ensureAndActivate.bat"
call "%scriptsDir%\ensureAndActivate.bat"
if ERRORLEVEL 1 goto :EOF
)
py -m pip freeze >%1
Expand Down
6 changes: 5 additions & 1 deletion venvUtils/venvCmd.bat
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,16 @@ if "%VIRTUAL_ENV%" NEQ "" (
call %*
goto :EOF
)
set hereOrig=%~dp0
set here=%hereOrig%
if #%hereOrig:~-1%# == #\# set here=%hereOrig:~0,-1%
set scriptsDir=%here%

rem call setlocal to make sure that any environment variable changes made by activating the virtual environment
rem can be completely undone when endlocal is called or this script exits.
setlocal
echo Ensuring NVDA Python virtual environment
call "%~dp0\ensureAndActivate.bat"
call "%scriptsDir%\ensureAndActivate.bat"
if ERRORLEVEL 1 goto :EOF
echo call %*
call %*
Expand Down

0 comments on commit ebb05fe

Please sign in to comment.