@Test
  public void testTxStoreWithDataSource2() {
    SpringBusFactory factory = new SpringBusFactory();
    Bus bus = factory.createBus("org/apache/cxf/ws/rm/persistence/jdbc/txstore-ds-bean2.xml");
    RMManager manager = bus.getExtension(RMManager.class);
    assertNotNull(manager);
    RMTxStore store = (RMTxStore) manager.getStore();

    assertNotNull(store.getDataSource());

    assertNull(store.getConnection());
  }
  @Test
  public void testSetCustomTableExistsState2() {
    SpringBusFactory factory = new SpringBusFactory();
    Bus bus =
        factory.createBus("org/apache/cxf/ws/rm/persistence/jdbc/txstore-custom-error-bean2.xml");
    RMManager manager = bus.getExtension(RMManager.class);
    assertNotNull(manager);
    RMTxStore store = (RMTxStore) manager.getStore();

    assertTrue(store.isTableExistsError(new SQLException("Table exists", "I6000", 288)));

    assertFalse(store.isTableExistsError(new SQLException("Unknown error", "00000", -1)));
  }
  /**
   * Accepts a new resend candidate.
   *
   * @param ctx the message context.
   * @return ResendCandidate
   */
  protected ResendCandidate cacheUnacknowledged(Message message) {
    RMProperties rmps = RMContextUtils.retrieveRMProperties(message, true);
    SequenceType st = rmps.getSequence();
    Identifier sid = st.getIdentifier();
    String key = sid.getValue();

    ResendCandidate candidate = null;

    synchronized (this) {
      List<ResendCandidate> sequenceCandidates = getSequenceCandidates(key);
      if (null == sequenceCandidates) {
        sequenceCandidates = new ArrayList<ResendCandidate>();
        candidates.put(key, sequenceCandidates);
      }
      candidate = new ResendCandidate(message);
      if (isSequenceSuspended(key)) {
        candidate.suspend();
      }
      sequenceCandidates.add(candidate);
      unacknowledgedCount++;
    }
    LOG.fine("Cached unacknowledged message.");
    try {
      RMEndpoint rme = manager.getReliableEndpoint(message);
      rme.handleAccept(key, st.getMessageNumber(), message);
    } catch (RMException e) {
      LOG.log(Level.WARNING, "Could not find reliable endpoint for message");
    }
    return candidate;
  }
 @Test
 public void testTxStoreBean() {
   // connect exception only results in a log message
   SpringBusFactory factory = new SpringBusFactory();
   Bus bus = factory.createBus("org/apache/cxf/ws/rm/persistence/jdbc/txstore-bean.xml");
   RMManager manager = bus.getExtension(RMManager.class);
   assertNotNull(manager);
   RMTxStore store = (RMTxStore) manager.getStore();
   assertNotNull(store);
   assertNull("Connection should be null", store.getConnection());
   assertEquals("org.apache.derby.jdbc.NoDriver", store.getDriverClassName());
   assertEquals("scott", store.getUserName());
   assertEquals("tiger", store.getPassword());
   assertEquals("jdbc:derby://localhost:1527/rmdb;create=true", store.getUrl());
   assertNull("schema should be unset", store.getSchemaName());
 }
 private void purgeCandidates(SourceSequence seq, boolean any) {
   Collection<Long> purged = new ArrayList<Long>();
   Collection<ResendCandidate> resends = new ArrayList<ResendCandidate>();
   Identifier sid = seq.getIdentifier();
   synchronized (this) {
     LOG.fine("Start purging resend candidates.");
     List<ResendCandidate> sequenceCandidates = getSequenceCandidates(seq);
     if (null != sequenceCandidates) {
       for (int i = sequenceCandidates.size() - 1; i >= 0; i--) {
         ResendCandidate candidate = sequenceCandidates.get(i);
         long m = candidate.getNumber();
         if (any || seq.isAcknowledged(m)) {
           sequenceCandidates.remove(i);
           candidate.resolved();
           unacknowledgedCount--;
           purged.add(m);
           resends.add(candidate);
         }
       }
       if (sequenceCandidates.isEmpty()) {
         candidates.remove(sid.getValue());
       }
     }
     LOG.fine("Completed purging resend candidates.");
   }
   if (purged.size() > 0) {
     RMStore store = manager.getStore();
     if (null != store) {
       store.removeMessages(sid, purged, true);
     }
     RMEndpoint rmEndpoint = seq.getSource().getReliableEndpoint();
     for (ResendCandidate resend : resends) {
       rmEndpoint.handleAcknowledgment(sid.getValue(), resend.getNumber(), resend.getMessage());
     }
   }
 }
  private void doResend(SoapMessage message) {
    try {

      // initialize copied interceptor chain for message
      PhaseInterceptorChain retransmitChain = manager.getRetransmitChain(message);
      ProtocolVariation protocol = RMContextUtils.getProtocolVariation(message);
      Endpoint endpoint = manager.getReliableEndpoint(message).getEndpoint(protocol);
      PhaseChainCache cache = new PhaseChainCache();
      boolean after = true;
      if (retransmitChain == null) {

        // no saved retransmit chain, so construct one from scratch (won't work for WS-Security on
        // server, so
        //  need to fix)
        retransmitChain = buildRetransmitChain(endpoint, cache);
        after = false;
      }
      message.setInterceptorChain(retransmitChain);

      // clear flag for SOAP out interceptor so envelope will be written
      message.remove(SoapOutInterceptor.WROTE_ENVELOPE_START);

      // discard all saved content
      Set<Class<?>> formats = message.getContentFormats();
      List<CachedOutputStreamCallback> callbacks = null;
      for (Class<?> clas : formats) {
        Object content = message.getContent(clas);
        if (content != null) {
          LOG.info(
              "Removing "
                  + clas.getName()
                  + " content of actual type "
                  + content.getClass().getName());
          message.removeContent(clas);
          if (clas == OutputStream.class && content instanceof WriteOnCloseOutputStream) {
            callbacks = ((WriteOnCloseOutputStream) content).getCallbacks();
          }
        }
      }

      // read SOAP headers from saved input stream
      RewindableInputStream is =
          (RewindableInputStream) message.get(RMMessageConstants.SAVED_CONTENT);
      is.rewind();
      XMLStreamReader reader = StaxUtils.createXMLStreamReader(is, "UTF-8");
      message.getHeaders().clear();
      if (reader.getEventType() != XMLStreamConstants.START_ELEMENT
          && reader.nextTag() != XMLStreamConstants.START_ELEMENT) {
        throw new IllegalStateException("No document found");
      }
      readHeaders(reader, message);
      int event;
      while ((event = reader.nextTag()) != XMLStreamConstants.START_ELEMENT) {
        if (event == XMLStreamConstants.END_ELEMENT) {
          throw new IllegalStateException("No body content present");
        }
      }

      // set message addressing properties
      AddressingProperties maps = new MAPCodec().unmarshalMAPs(message);
      RMContextUtils.storeMAPs(maps, message, true, MessageUtils.isRequestor(message));
      AttributedURIType to = null;
      if (null != maps) {
        to = maps.getTo();
      }
      if (null == to) {
        LOG.log(Level.SEVERE, "NO_ADDRESS_FOR_RESEND_MSG");
        return;
      }
      if (RMUtils.getAddressingConstants().getAnonymousURI().equals(to.getValue())) {
        LOG.log(Level.FINE, "Cannot resend to anonymous target");
        return;
      }

      // initialize conduit for new message
      Conduit c = message.getExchange().getConduit(message);
      if (c == null) {
        c = buildConduit(message, endpoint, to);
      }
      c.prepare(message);

      // replace standard message marshaling with copy from saved stream
      ListIterator<Interceptor<? extends Message>> iterator = retransmitChain.getIterator();
      while (iterator.hasNext()) {
        Interceptor<? extends Message> incept = iterator.next();

        // remove JAX-WS interceptors which handle message modes and such
        if (incept.getClass().getName().startsWith("org.apache.cxf.jaxws.interceptors")) {
          retransmitChain.remove(incept);
        } else if (incept instanceof PhaseInterceptor
            && (((PhaseInterceptor<?>) incept).getPhase() == Phase.MARSHAL)) {

          // remove any interceptors from the marshal phase
          retransmitChain.remove(incept);
        }
      }
      retransmitChain.add(new CopyOutInterceptor(reader));

      // restore callbacks on output stream
      if (callbacks != null) {
        OutputStream os = message.getContent(OutputStream.class);
        if (os != null) {
          WriteOnCloseOutputStream woc;
          if (os instanceof WriteOnCloseOutputStream) {
            woc = (WriteOnCloseOutputStream) os;
          } else {
            woc = new WriteOnCloseOutputStream(os);
            message.setContent(OutputStream.class, woc);
          }
          for (CachedOutputStreamCallback cb : callbacks) {
            woc.registerCallback(cb);
          }
        }
      }

      // send the message
      message.put(RMMessageConstants.RM_RETRANSMISSION, Boolean.TRUE);
      if (after) {
        retransmitChain.doInterceptStartingAfter(message, RMCaptureOutInterceptor.class.getName());
      } else {
        retransmitChain.doIntercept(message);
      }
      if (LOG.isLoggable(Level.INFO)) {
        RMProperties rmps = RMContextUtils.retrieveRMProperties(message, true);
        SequenceType seq = rmps.getSequence();
        LOG.log(
            Level.INFO,
            "Retransmitted message "
                + seq.getMessageNumber()
                + " in sequence "
                + seq.getIdentifier().getValue());
        rmps = new RMProperties();
      }

    } catch (Exception ex) {
      LOG.log(Level.SEVERE, "RESEND_FAILED_MSG", ex);
    }
  }