我如何使用JUnit测试void actionEvent中的信息

如何解决我如何使用JUnit测试void actionEvent中的信息

我试图从一个空的actionEvent中获取信息,以便可以将其用于JUnit测试(第一次尝试使用JUnit)。但是我不确定该怎么做。如果有人可以提出一些指导,我将不胜感激。 这是下面的代码。 (此代码仅用于与JUnit一起测试,我知道它的垃圾酱。

import java.awt.Container;
import javax.swing.JTextField;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.JButton;
import javax.swing.JOptionPane;
import javax.swing.JPasswordField;
import javax.swing.JFrame;
import javax.swing.JLabel;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.net.UnknownHostException;
import java.time.OffsetDateTime;
import java.time.ZoneOffset;


public class frameIt extends JFrame implements ActionListener {

    Container cont = getContentPane();
    JLabel uL = new JLabel("USER");
    JLabel pL = new JLabel("PASS");
    JTextField userT1 = new JTextField();
    JPasswordField pass1 = new JPasswordField();
    JButton logButt = new JButton("LOGIN");
    JButton reButt = new JButton("RESET");
    


    frameIt() {
        
        cont.setLayout(null);
    
        uL.setBounds(20,50,20);
        pL.setBounds(20,80,20);
        userT1.setBounds(70,100,30);
        pass1.setBounds(70,30);
        logButt.setBounds(70,30);
        reButt.setBounds(70,130,30);
       
        cont.add(logButt);
        cont.add(reButt);
        cont.add(uL);
        cont.add(pL);
        cont.add(userT1);
        cont.add(pass1);
    
        logButt.addActionListener(this);
        reButt.addActionListener(this);

    }

//auditing
    public String theLog(String user,String eventType) throws UnknownHostException {
        //UTC date and time string
        OffsetDateTime dateTimeUTC = OffsetDateTime.now(ZoneOffset.UTC);

        // create date and time string
        Date dateTimeLocal = Date.from(dateTimeUTC.toInstant());

        // create filewriter,bufferedwriter,and printwriter
        FileWriter FWrite = null;
        BufferedWriter buffWrite = null;
        PrintWriter printerWrite = null;

        // try block
        try {
            // create file
            File logFile = new File("Log.log");

            // check if file already exists
            // if file does not exist then create it
            if (!logFile.exists()) {
                logFile.createNewFile();
            }

            //filewriter,and printwriter
            FWrite = new FileWriter(logFile,true);
            buffWrite = new BufferedWriter(FWrite);
            printerWrite = new PrintWriter(buffWrite);

            //printwriter
           
            printerWrite.println("----------------------");
            printerWrite.println("UTC Date/Time: " + dateTimeUTC);
            printerWrite.println("Local Date/Time: " + dateTimeLocal);
            printerWrite.println("User name: " + user);
            printerWrite.println("Event type: " + eventType);
            printerWrite.println("----------------------");
            printerWrite.println("");

        } 
        // catch block 
        
        catch (IOException e) {
            System.out.println("Sorry,there was an error.");
        } finally {
           
            // printwriter
            printerWrite.close();
        }

        return null;
    }
    
    
    
    public void actionPerformed(ActionEvent aE)  {
       
        
        
    if (aE.getSource() == reButt) {
            userT1.setText("");
            pass1.setText("");
            
        }
    
        if (aE.getSource() == logButt) {
            
            String userText = userT1.getText();
            String pwdText = String.valueOf(pass1.getPassword());
           
            try {
            
            if (userText.equals("admin") && pwdText.equals("admin")) {
                theLog(userText,"Good Login");
                JOptionPane.showMessageDialog(this,"Login Correct");
            } else {
                JOptionPane.showMessageDialog(this,"try again");
                theLog(userText,"Failed Login");
            }

        }
            
         catch (IOException ex) {
                Logger.getLogger(frameIt.class.getName()).log(Level.SEVERE,null,ex);
                
            }
                 
        
     


          }
        }
    
    public static void main(String[] args) {
        //calling frameIt.java
        frameIt frame = new frameIt();
        //title
        frame.setTitle("Sign on Forever");
        //Want to see it? this is how!
        frame.setVisible(true);
        //Window size
        frame.setBounds(15,15,300,300);
        //exits
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

    }
    
    }
    

解决方法

您可以在这里看到此文章:https://examples.javacodegeeks.com/core-java/junit/junit-test-void-method-example/

,

我发现,与其尝试执行此操作,不如将ActionEvent的内容从单击按钮转换为身份验证更容易。这样的。

btnLogout.setOnAction((ActionEvent e) -> {
            doLogin();
        });

,然后将其他所有内容放入doLogin中。 @Spindoctor的答案是好的,应该计算在内。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 <select id="xxx"> SELECT di.id, di.name, di.work_type, di.updated... <where> <if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 <property name="dynamic.classpath" value="tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams['font.sans-serif'] = ['SimHei'] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -> systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping("/hires") public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate<String
使用vite构建项目报错 C:\Users\ychen\work>npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-