You are viewing a plain text version of this content. The canonical link for it is here.
Posted to common-dev@hadoop.apache.org by "Takanobu Asanuma (Jira)" <ji...@apache.org> on 2021/05/12 01:37:00 UTC

[jira] [Resolved] (HADOOP-17686) Avoid potential NPE by using Path#getParentPath API in hadoop-huaweicloud

     [ https://issues.apache.org/jira/browse/HADOOP-17686?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Takanobu Asanuma resolved HADOOP-17686.
---------------------------------------
    Fix Version/s: 3.4.0
       Resolution: Fixed

> Avoid potential NPE by using Path#getParentPath API in hadoop-huaweicloud
> -------------------------------------------------------------------------
>
>                 Key: HADOOP-17686
>                 URL: https://issues.apache.org/jira/browse/HADOOP-17686
>             Project: Hadoop Common
>          Issue Type: Bug
>          Components: fs
>            Reporter: Error Reporter
>            Assignee: Viraj Jasani
>            Priority: Major
>              Labels: pull-request-available
>             Fix For: 3.4.0
>
>          Time Spent: 2h
>  Remaining Estimate: 0h
>
> Hello,
> Our code analyses found a following potential NPE:
>  
> {code:java}
> public Path getParent() {
>     String path = uri.getPath();
>     int lastSlash = path.lastIndexOf('/');
>     int start = startPositionWithoutWindowsDrive(path);
>     if ((path.length() == start) ||               // empty path
>         (lastSlash == start && path.length() == start+1)) { // at root
>       return null; <--- Null returned
>     }
> {code}
>  
> {code:java}
> private static void getDirectories(final String key, final String sourceKey,
>       final Set<String> directories) {
>     Path p = new Path(key);
>     Path sourcePath = new Path(sourceKey);
>     // directory must add first
>     if (key.endsWith("/") && p.compareTo(sourcePath) > 0) {
>       directories.add(p.toString());
>     }
>     while (p.compareTo(sourcePath) > 0) {
>       p = p.getParent(); <--- NPE
>       if (p.isRoot() || p.compareTo(sourcePath) == 0) {
>         break;
>       }
> {code}
> Given a root path, it will lead to NPE at method getDirectories
>  
> Full trace:
>  
> 1. Return null to caller
> [https://github.com/apache/hadoop/blob/f40e3eb0590f85bb42d2471992bf5d524628fdd6/hadoop-common-project/hadoop-common/src/main/java/org/apache/hadoop/fs/Path.java#L432]
> 2. Function getParent executes and returns
> [https://github.com/apache/hadoop/blob/f40e3eb0590f85bb42d2471992bf5d524628fdd6/hadoop-cloud-storage-project/hadoop-huaweicloud/src/main/java/org/apache/hadoop/fs/obs/OBSObjectBucketUtils.java#L875]
> 3. The return value of function getParent is passed as the this pointer to function isRoot (the return value of function getParent can be null)
> [https://github.com/apache/hadoop/blob/f40e3eb0590f85bb42d2471992bf5d524628fdd6/hadoop-cloud-storage-project/hadoop-huaweicloud/src/main/java/org/apache/hadoop/fs/obs/OBSObjectBucketUtils.java#L876]
> Commit: f40e3eb0590f85bb42d2471992bf5d524628fdd6



--
This message was sent by Atlassian Jira
(v8.3.4#803005)

---------------------------------------------------------------------
To unsubscribe, e-mail: common-dev-unsubscribe@hadoop.apache.org
For additional commands, e-mail: common-dev-help@hadoop.apache.org