I want to use bootstrap with JSF 2.1, the most important thing is that data-toggle attribute can be used. The implementation for h:inputText works fine. However, when I tried to do the same with h:selectOneMenu the renderer doesn't seem to be called (I put a breakpoint on startElement method). I used a documentary approach to find the renderer type and the component family.
This is my SelectRenderer.java. I took as a reference dilek's code
import com.sun.faces.renderkit.html_basic.TextRenderer;
import java.io.IOException;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.context.ResponseWriter;
import javax.faces.context.ResponseWriterWrapper;
/**
 * @link https://stackoverflow.com/a/7886942/4253946
 */
public class InputRenderer extends com.sun.faces.renderkit.html_basic.TextRenderer {
    private static final String[] ATTRIBUTES = { "data-toggle" };
    @Override
    protected void getEndTextToRender(FacesContext context, UIComponent component,
                                      String currentValue) throws IOException {
        final ResponseWriter originalResponseWriter = context.getResponseWriter();
        context.setResponseWriter(new ResponseWriterWrapper() {
            @Override
            // As of JSF 1.2 this method is now public.
            public ResponseWriter getWrapped() {
                return originalResponseWriter;
            }
            @Override
            public void startElement(String name, UIComponent component) throws IOException {
                super.startElement(name, component);
                if ("input".equals(name)) {
                    for (String attribute : ATTRIBUTES) {
                        Object value = component.getAttributes().get(attribute);
                        if (value != null) {
                            super.writeAttribute(attribute, value, attribute);
                        }
                    }
                }
            }
        });
        super.getEndTextToRender(context, component, currentValue);
        context.setResponseWriter(originalResponseWriter); // Restore original writer.
    }
}
This is my faces-config.xml
<?xml version="1.0" encoding="UTF-8"?>
<faces-config version="2.1" xmlns="http://java.sun.com/xml/ns/javaee">
    <render-kit>
        <renderer>
            <component-family>javax.faces.Input</component-family>
            <renderer-type>javax.faces.Text</renderer-type>
            <renderer-class>InputRenderer</renderer-class>
        </renderer>
        <renderer>
            <component-family>javax.faces.SelectOne</component-family>
            <renderer-type>javax.faces.Menu</renderer-type>
            <renderer-class>SelectRenderer</renderer-class>
        </renderer>
    </render-kit>
</faces-config>
fragment of index.xhtml
<div class="form-group">
    <h:outputLabel class="col-md-4 control-label" for="mySelect">my Label Select</h:outputLabel>
    <div class="col-md-7">
        <h:selectOneMenu  id="mySelect" name="mySelect" class="form-control" data-toggle='tooltip'>
            <f:selectItem itemValue="0" itemLabel="Dummy Label 1" />
            <f:selectItem itemValue="1" itemLabel="Dummy Label 1" />
        </h:selectOneMenu >
    </div>
</div>
UPDATE I I changed javax.faces.Input to javax.faces.SelectOne
¿Why the attribute doesn't pass to the rendered html?