Erro no estranho no JDBC não conisgo recuperar uma consulta com JOIN

Boa noite pessoal estou com dificuldades em uma consulta oa banco o JDBC não consegue recuperar ela dados de duas tabelas.

vejam minha casse DAO ai

package br.com.drograria.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;

import br.com.drogaria.domain.Fabricante;
import br.com.drogaria.domain.Produto;
import br.com.drograria.factory.ConexaoFactory;

public class ProdutoDAO {
    Connection con = ConexaoFactory.getConnection();

    public void salvar(Produto produto) throws SQLException {

        String sql = "INSERT INTO produto (descricao, quantidade, preco, fabricante_codigo) VALUES(?,?,?,?)";
        PreparedStatement stm = con.prepareStatement(sql);

        stm.setString(1, produto.getDescricao());
        stm.setInt(2, produto.getQuantidade());
        stm.setDouble(3, produto.getPreco());
        stm.setLong(4, produto.getFabricante().getCodigo());

        stm.executeUpdate();
        stm.close();
    }

    public ArrayList<Produto> listar() throws SQLException {

        
        String sql ="SELECT p.codigo, p.descricao, p.preco, p.quantidade, f.codigo, f.descricao FROM produto p INNER JOIN fabricante f ON  f.codigo = p.fabricante_codigo ";        
        
        PreparedStatement stm = con.prepareStatement(sql);
        ResultSet rs = stm.executeQuery();

        ArrayList<Produto> itens = new ArrayList<Produto>();

        while (rs.next()) {
            Fabricante f = new Fabricante();
            f.setCodigo(rs.getInt("f.numero"));
            f.setDescricao(rs.getString("f.descricao"));

            Produto p = new Produto();
            p.setCodigo(rs.getInt("codigo"));
            p.setDescricao(rs.getString("descricao"));
            p.setPreco(rs.getDouble("preco"));
            p.setQuantidade(rs.getInt("quantidade"));
        //    p.setFabricante(f);

            itens.add(p);
        }

        return itens;

    }

}

veja minha calsse teste

package br.com.drogaria.test;

import java.sql.SQLException;
import java.util.ArrayList;

import org.junit.Test;

import br.com.drogaria.domain.Fabricante;
import br.com.drogaria.domain.Produto;
import br.com.drograria.dao.ProdutoDAO;

public class ProdutoDAOTest {
    @Test
    @org.junit.Ignore
    public void salvar()throws SQLException{
        Produto p = new Produto();
        p.setDescricao("Anador");
        p.setPreco(3.00);
        p.setQuantidade(16);
        
        Fabricante f = new Fabricante();
        f.setCodigo(4);
        
        p.setFabricante(f);
        
        ProdutoDAO dao = new ProdutoDAO();
        
        dao.salvar(p);
    }
    @Test
    public void listar() throws SQLException{
        ProdutoDAO dao = new ProdutoDAO();
        ArrayList<Produto> lista = dao.listar();
        
    /*    for(Produto p: lista){
            System.out.println("Codigo"+ p.getCodigo());
            System.out.println("Descrição "+ p.getDescricao());
            System.out.println("Preço "+ p.getPreco());
            System.out.println("Quatindade"+ p.getCodigo());



        }*/
        
    }
}

o erro que estou tendo

Ha lembrando eu já testei o comando sql no banco e funciona normal.

org.postgresql.util.PSQLException: A nome da coluna f.numero não foi encontrado neste ResultSet.
    at org.postgresql.jdbc2.AbstractJdbc2ResultSet.findColumn(AbstractJdbc2ResultSet.java:2803)
    at org.postgresql.jdbc2.AbstractJdbc2ResultSet.getInt(AbstractJdbc2ResultSet.java:2664)
    at br.com.drograria.dao.ProdutoDAO.listar(ProdutoDAO.java:42)
    at br.com.drogaria.test.ProdutoDAOTest.listar(ProdutoDAOTest.java:33)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)



    at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

o stack trace parece bem explícito.

descosider o f.setCodigo(rs.getInt(“f.numero”)); e correto como está é f.setCodigo(rs.getInt(“f.codigo”));

mas mesmo assim da erro e quando pego o comando sql e vou testar no PGAdmin ele roda normal.

Qual excecão esta sendo lançada ? esta usando netbeans ?
Veja as linhas que mostra :
(ProdutoDAO.java:42)
(ProdutoDAOTest.java:33

por que voce setou o p.setfabricante(f) e depois deixou comentado ?

TEC.ER eu comentei pra testar aqui mais já corrigi estou usando o eclips e testando cm JUINit

a exceção é SQLException.

Não entendo seus testes, você anota com @Test, mas não faz assert de nada, é um main isso ai, enfim.
Tá mas se você mudou, qual o erro de agora ? já que trocou a string que pega no rs

e o mesmo erro junit diz que a coluna f.descricao não foi encontrada mo resultset

pesquisando aqui resolvi pessoal vejam como deveria ficar o codigo

public ArrayList<Produto> listar() throws SQLException {

        Connection con = ConnexaoFactory.getConnection();

        String sql = "SELECT  f.descricao, f.codigo,  p.codigo, p.descricao, p.preco, p.quantidade from produto p INNER JOIN fabricante f on f.codigo = p.fabricante_codigo";
        
                PreparedStatement stm = con.prepareStatement(sql);
        ResultSet rs = stm.executeQuery();

        ArrayList<Produto> itens = new ArrayList<Produto>();

        while (rs.next()) {
            Fabricante fab = new Fabricante();
            fab.setDescricao(rs.getString(1));
            fab.setCodigo(rs.getInt(2));
    
            Produto p = new Produto();
            p.setCodigo(rs.getInt(3));
            p.setDescricao(rs.getString(4));
            p.setPreco(rs.getDouble(5));
            p.setQuantidade(rs.getInt(6));
            p.setFabricante(fab);

            itens.add(p);
        }

        return itens;

    }

A Exception é bem clara, quando executa esse SQL o banco não retorna “f.codigo” mas sim “codigo”, pegue sua consulta e execute diretamente no bd para ver o resultado. Resumindo: f.setCodigo(rs.getInt(“numero”));

Ainda bem que resolveu.

Voce tambem poderia somente tira o f da frente e deixa os nomes iguais aos da coluna do banco , pois f.numero , não e um nome da coluna por isso o erro.