Return-Path: X-Original-To: apmail-cxf-issues-archive@www.apache.org Delivered-To: apmail-cxf-issues-archive@www.apache.org Received: from mail.apache.org (hermes.apache.org [140.211.11.3]) by minotaur.apache.org (Postfix) with SMTP id 84DDF10106 for ; Thu, 18 Jul 2013 06:13:02 +0000 (UTC) Received: (qmail 89375 invoked by uid 500); 18 Jul 2013 06:13:02 -0000 Delivered-To: apmail-cxf-issues-archive@cxf.apache.org Received: (qmail 89237 invoked by uid 500); 18 Jul 2013 06:12:57 -0000 Mailing-List: contact issues-help@cxf.apache.org; run by ezmlm Precedence: bulk List-Help: List-Unsubscribe: List-Post: List-Id: Reply-To: dev@cxf.apache.org Delivered-To: mailing list issues@cxf.apache.org Received: (qmail 89083 invoked by uid 99); 18 Jul 2013 06:12:55 -0000 Received: from arcas.apache.org (HELO arcas.apache.org) (140.211.11.28) by apache.org (qpsmtpd/0.29) with ESMTP; Thu, 18 Jul 2013 06:12:55 +0000 Date: Thu, 18 Jul 2013 06:12:55 +0000 (UTC) From: "Jim Ma (JIRA)" To: issues@cxf.apache.org Message-ID: In-Reply-To: References: Subject: [jira] [Assigned] (CXF-4836) ServiceImpl getPort does not need to throw Exception if the portName can not be found in portInfos MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 7bit X-JIRA-FingerPrint: 30527f35849b9dde25b450d4833f0394 [ https://issues.apache.org/jira/browse/CXF-4836?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ] Jim Ma reassigned CXF-4836: --------------------------- Assignee: Jim Ma > ServiceImpl getPort does not need to throw Exception if the portName can not be found in portInfos > -------------------------------------------------------------------------------------------------- > > Key: CXF-4836 > URL: https://issues.apache.org/jira/browse/CXF-4836 > Project: CXF > Issue Type: Bug > Components: JAX-WS Runtime > Affects Versions: 2.6.2 > Reporter: Yan Min Sheng > Assignee: Jim Ma > > We create such client which will set target address info and binding info in RequestContext of BindingProvider. > String mtom11URL = "http://localhost:9080//MyBusiness/MTOM11Service"; > > MTOMInterface port = null; > BindingProvider bp = null; > > System.out.println("Looking up SOAP 1.1 MTOM service"); > QName serviceName = new QName("http://shengym.com/MyBusiness/","MTOM11Service"); > QName portName = new QName("http://shengym.com/MyBusiness", "MTOM11Port"); > // Setup the necessary JAX-WS artifacts > Service svc = Service.create(serviceName); > port = svc.getPort(portName, MTOMInterface.class); > // Set the target URL > bp = (BindingProvider) port; > Map requestCtx = bp.getRequestContext(); > requestCtx.put(BindingProvider.ENDPOINT_ADDRESS_PROPERTY,mtom11URL); > > // Enable MTOM > SOAPBinding binding = (SOAPBinding) bp.getBinding(); > binding.setMTOMEnabled(true); > However, it reports such error: > javax.xml.ws.WebServiceException:Port{http://shengym.com/MyBusiness/}MTOM11Port not found. > org.apache.cxf.jaxws.ServiceImpl.getPort(ServiceImpl.java:332) > org.apache.cxf.jaxws.ServiceImpl.getPort(ServiceImpl.java:323) > javax.xml.ws.Service.getPort(Service.java:134) > I know that the added following code can fix this error: > svc.addPort(portName, SOAPBinding.SOAP11HTTP_MTOM_BINDING, mtom11URL); > Well, this error should not report even the addPort method is not called. > I know the added check in ServiceImpl is to avoid run time error and report it as early as possible. But I think it is not needed. The reasons are: > 1. User can get run time error later; > 2. User can set target addess info and bind info in other ways (as my example shows) > I remove the check from the ServiceImpl then my client code works well. -- This message is automatically generated by JIRA. If you think it was sent incorrectly, please contact your JIRA administrators For more information on JIRA, see: http://www.atlassian.com/software/jira