RFR : 8182672: Java 8u121 on Linux intermittently returns null for MAC address

Langer, Christoph christoph.langer at sap.com
Fri Jun 23 13:40:11 UTC 2017


Hi,

looks like a great piece of modern concurrent Java coding :) Well done! +1

Best regards
Christoph

> -----Original Message-----
> From: Chris Hegarty [mailto:chris.hegarty at oracle.com]
> Sent: Freitag, 23. Juni 2017 15:28
> To: Seán Coffey <sean.coffey at oracle.com>; Langer, Christoph
> <christoph.langer at sap.com>
> Cc: net-dev <net-dev at openjdk.java.net>
> Subject: Re: RFR : 8182672: Java 8u121 on Linux intermittently returns null for
> MAC address
> 
> 
> 
> On 23/06/17 10:56, Seán Coffey wrote:
> > Thanks to Christoph, Vyom and Mark for the reviews.
> >
> > I've improved the testcase as per feedback. Hope this meets all requests :
> >
> > http://cr.openjdk.java.net/~coffeys/webrev.8182672.jdk10.v2/webrev/
> 
> The change looks good.
> 
> Sean and I did a live coding session and arrived at the following
> version of the test.
> 
> -Chris.
> 
> /*
>   * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
>   * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
>   *
>   * This code is free software; you can redistribute it and/or modify it
>   * under the terms of the GNU General Public License version 2 only, as
>   * published by the Free Software Foundation.
>   *
>   * This code is distributed in the hope that it will be useful, but WITHOUT
>   * ANY WARRANTY; without even the implied warranty of
> MERCHANTABILITY or
>   * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
> License
>   * version 2 for more details (a copy is included in the LICENSE file that
>   * accompanied this code).
>   *
>   * You should have received a copy of the GNU General Public License
> version
>   * 2 along with this work; if not, write to the Free Software Foundation,
>   * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
>   *
>   * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065
> USA
>   * or visit www.oracle.com if you need additional information or have any
>   * questions.
>   */
> 
> /*
>   * @test
>   * @bug 8182672
>   * @summary Java 8u121 on Linux intermittently returns null for MAC
> address
>   */
> 
> import java.net.NetworkInterface;
> import java.util.ArrayList;
> import java.util.List;
> import java.util.concurrent.Callable;
> import java.util.concurrent.ExecutorService;
> import java.util.concurrent.Executors;
> import java.util.concurrent.Future;
> import java.util.concurrent.Phaser;
> import java.util.function.Predicate;
> import java.util.stream.Collectors;
> 
> public class GetMacAddress implements Callable<Exception> {
>      static final int NUM_THREADS = 5;
>      static final int NUM_ITERS = 100;
>      static volatile boolean failed; // false
> 
>      final String threadName;
>      final NetworkInterface ni;
>      final Phaser startingGate;
> 
>      public GetMacAddress(NetworkInterface ni, String name, Phaser phaser) {
>          this.ni = ni;
>          this.threadName = name;
>          this.startingGate = phaser;
>      }
> 
>      @Override
>      public Exception call() {
>          int count = 0;
>          startingGate.arriveAndAwaitAdvance();
>          try {
>              for (int i = 0; i < NUM_ITERS; i++) {
>                  ni.getMTU();
>                  byte[] addr = ni.getHardwareAddress();
>                  if (addr == null) {
>                      System.out.println(threadName + ". mac id is null");
>                      failed = true;
>                  }
>                  count = count + 1;
>                  if (count % 100 == 0) {
>                      System.out.println(threadName + ". count is " + count);
>                  }
>              }
>          } catch (Exception ex) {
>              System.out.println(threadName + ". Not expecting
> exception:" + ex.getMessage());
>              failed = true;
>              return ex;
>          }
>          return null;
>      }
> 
>      static final Predicate<NetworkInterface> hasHardwareAddress = ni -> {
>          try {
>              if (ni.getHardwareAddress() == null) {
>                  System.out.println("Not testing null addr: " +
> ni.getName());
>                  return false;
>              }
>          } catch (Exception ex) {
>              System.out.println("Not testing: " + ni.getName() +
>                      " " + ex.getMessage());
>          }
>          return true;
>      };
> 
>      public static void main(String[] args) throws Exception {
>          List<NetworkInterface> toTest =
> NetworkInterface.networkInterfaces()
>                          .filter(hasHardwareAddress)
>                          .collect(Collectors.toList());
> 
>          ExecutorService executor =
> Executors.newFixedThreadPool(NUM_THREADS);
> 
>          for (NetworkInterface ni : toTest) {
>              Phaser startingGate = new Phaser(NUM_THREADS);
>              System.out.println("Testing: " + ni.getName());
>              List<Callable<Exception>> list = new ArrayList<>();
>              for (int i = 0; i < NUM_THREADS; i++)
>                  list.add(new GetMacAddress(ni, ni.getName() +
> "-Thread-" + i, startingGate));
>              List<Future<Exception>> futures = executor.invokeAll(list);
>              for (Future<Exception> f : futures) {
>                  if (f.get() != null)
>                      f.get().printStackTrace(System.out);
>              }
>              if (failed)
>                  break;
>          }
>          executor.shutdownNow();
>          if (!failed) {
>              System.out.println("PASSED - Finished all threads");
>          } else {
>              throw new RuntimeException("Failed");
>          }
>      }
> }


More information about the net-dev mailing list