Opened 2 years ago
Closed 2 years ago
#55897 closed enhancement (fixed)
Add tests for path_join()
Reported by: | karlijnbk | Owned by: | karlijnbk |
---|---|---|---|
Milestone: | 6.1 | Priority: | normal |
Severity: | normal | Version: | 6.1 |
Component: | General | Keywords: | has-patch has-unit-tests |
Focuses: | Cc: |
Description
Change History (14)
This ticket was mentioned in PR #2774 on WordPress/wordpress-develop by karlijnbok.
2 years ago
#1
- Keywords has-patch has-unit-tests added
SergeyBiryukov commented on PR #2774:
2 years ago
#5
Thanks for the PR! Merged in https://core.trac.wordpress.org/changeset/53457.
#6
@
2 years ago
Hi there, welcome to WordPress Trac! Thanks for the ticket and the PR, this looks great.
Keeping the ticket open for now to address the notes from your PR.
#8
follow-up:
↓ 9
@
2 years ago
Remove redundant
ltrim()
frompath_join()
Isn't it only redundant in the second return in path_join
? It seems like the ltrim
should be used in the first return. There is no test case for a path with multiple slashes.
Also, the path_is_absolute
function checks for /
or \
, so should these paths be normalized first, before joining them?
#9
in reply to:
↑ 8
;
follow-up:
↓ 13
@
2 years ago
Replying to joyously:
Isn't it only redundant in the second return in
path_join
? It seems like theltrim
should be used in the first return.
There is no test case for a path with multiple slashes.
Also, thepath_is_absolute
function checks for/
or\
, so should these paths be normalized first, before joining them?
Good suggestions, thanks! Yes, it was only redundant in (and is now removed from) the second return.
Looks like you're right about including it in the first return, and we should include a test case for a path with multiple slashes.
I'm not sure about normalizing the paths though. Looking at how path_join()
is used in core, I don't see any immediate issues with mixed slashes there. On second thought, I don't see any harm in that, as it will indeed provide more consistent behavior.
#10
@
2 years ago
Regardless of the function, this ticket is about test cases, and the case of mixed slashes is not there. (not sure if it's in some existing test case)
2 years ago
#11
Two things I'd like to mention about the
path_join
method:
- Maybe some verification or checks should be added to make sure
$base
and$path
are both indeed strings. Newer php versions might break otherwise (PHP8 for instance can give a fatal error).- The
ltrim
for the path variable is redundant, because if thepath
variable starts with slashes, it will be considered absolute, thus entering the if statement and returning$path
. It will only reach theltrim( $path, '/' )
if$path
is not absolute, i.e. does not start with a slash, so nothing needs to be trimmed.
Well done @karlijnbok 👍🏻 and I concur on both your observations.
#13
in reply to:
↑ 9
@
2 years ago
Replying to SergeyBiryukov:
Looks like you're right about including it in the first return, and we should include a test case for a path with multiple slashes.
A test case was added in [53461].
Thinking about it some more, I believe the current behavior is correct: Windows supports any combination of two or more leading slashes or backslashes in network shares:
\\host\share
\\host/share
//host\share
//host/share
\\\host\share
\\\host/share
///host\share
///host/share
So using return '/' . ltrim( $path, '/' )
in case of an absolute path would break it, keeping only a single slash or introducing a mix of slashes. We could limit the leading slashes or backslashes to two, but that would make the function a bit more complicated without an obvious benefit.
There are a few further enhancements that could be made here:
- Making sure that
$base
and$path
are both indeed strings. This could use some discussion on how to handle and what to return in case of an invalid input. - Normalizing the slashes and adding test cases for mixed slashes.
- Limiting the leading slashes to two and adding test cases for more than two slashes.
I think they should be explored in a new ticket, as this one was focused on adding some tests for the current behavior.
Adds unit tests for
path_join
inbuild/wp-includes/functions.php
Trac ticket: https://core.trac.wordpress.org/ticket/55897#ticket
Two things I'd like to mention about the
path_join
method:$base
and$path
are both indeed strings.ltrim
for the path variable is redundant, because if thepath
variable starts with slashes, it will be considered absolute, thus entering the if statement and returning$path
. It will only reach theltrim( $path, '/' )
if$path
is not absolute, i.e. does not start with a slash, so nothing needs to be trimmed.