package com.siva.springboot.javaguruonline.repository; import java.sql.ResultSet; import java.util.ArrayList; import java.util.List; import org.junit.Assert; import org.junit.Test; import org.junit.runner.RunWith; import org.mockito.InjectMocks; import org.mockito.Mock; import org.mockito.Mockito; import org.mockito.invocation.InvocationOnMock; import org.mockito.stubbing.Answer; import org.springframework.jdbc.core.RowMapper; import org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate; import org.springframework.test.context.junit4.SpringRunner; import com.siva.springboot.javaguruonline.model.EmployeeDetails; @RunWith(SpringRunner.class) /** * * @author Siva * */ //@SpringBootTest(classes = SpringbootJpaSwaggerSonarqubeApplication.class) public class EmployeeDaoImplTest { @InjectMocks public EmployeeDaoImpl employeeDao; @Mock private NamedParameterJdbcTemplate namedParameterJdbcTemplate; @SuppressWarnings("unchecked") @Test public void testGetAllEmployeeDetails(){ Listlist = new ArrayList (); EmployeeDetails employeeDetails = new EmployeeDetails(); employeeDetails.setEmpId(1); employeeDetails.setEmpName("siva"); list.add(employeeDetails); Mockito.when(namedParameterJdbcTemplate.query(Mockito.anyString(), Mockito.any(RowMapper.class))) .thenAnswer(new Answer >() { @Override public List
answer(InvocationOnMock invocation) throws Throwable { // Fetch the method arguments Object[] args = invocation.getArguments(); // Fetch the row mapper instance from the arguments RowMapper rm = (RowMapper ) args[1]; // Create a mock result set and setup an expectation on it ResultSet rs = Mockito.mock(ResultSet.class); Mockito.when(rs.getInt("emp_id")).thenReturn(employeeDetails.getEmpId()); Mockito.when(rs.getString("emp_name")).thenReturn(employeeDetails.getEmpName()); // Invoke the row mapper EmployeeDetails actual = rm.mapRow(rs, 0); // Assert the result of the row mapper execution Assert.assertEquals(employeeDetails.getEmpName(), actual.getEmpName()); // Return your created list for the template#query call return list; } }); employeeDao.getEmployeeDetails(); Assert.assertNotNull(list); } }
Thursday, March 11, 2021
How to mock ResultSet , NamedParameterJdbcTemplate , RowMapper
Thursday, August 27, 2020
Getting started with Chatbot using java and response in text to speech -- Java simple chatbot and text to speech
This will explain you about , how we can write simple chatbot using java and read the bot response into speech
Step 1: Download sample program-ab from the below archive folder
Program-ab
Step 2: Unzip the downloaded folder.
Step 3: Create java maven project using any IDE or console application
Step 4: Copy Ab.jar (Which is there in the unzipped folder lib in step 2) add to the classpath
Step 5: Copy bots folder (which is available in the unzipped folder) it has all the aiml files, which bot act upon our request and give the response
Step 6: Now we need to give bot response in speech
Step 7: Download freetss from the given link
FREETTS
Step 8: Unzip the downloaded folder and go to \freetts-1.2.2-bin\freetts-1.2\lib folder
Step 9: Run the jsapi.exe file- It will generate multiple jars
Step 10: copy that jars and place it in the classpath of the java project
Step 11: Once above steps completed then, we can write simple java program as follows
package com.siva; import java.io.File; import java.util.Locale; import java.util.Scanner; import javax.speech.Central; import javax.speech.synthesis.Synthesizer; import javax.speech.synthesis.SynthesizerModeDesc; import org.alicebot.ab.AB; import org.alicebot.ab.Bot; import org.alicebot.ab.Chat; import org.alicebot.ab.MagicBooleans; import org.alicebot.ab.utils.IOUtils; public class TestChatbot { private static final boolean TRACE_MODE = false; static String botName = "super"; public static void main(String[] args) { try { String aimlResourcesPath = getResourcesPath(); System.out.println(aimlResourcesPath); MagicBooleans.trace_mode = TRACE_MODE; Bot bot = new Bot("super", aimlResourcesPath); Chat chatSession = new Chat(bot); AB.ab(bot); Scanner sc=new Scanner(System.in); String request = "Hai"; do{ request = IOUtils.readInputTextLine(); String response = chatSession.multisentenceRespond(request); // Set property as Kevin Dictionary System.setProperty( "freetts.voices", "com.sun.speech.freetts.en.us" + ".cmu_us_kal.KevinVoiceDirectory"); // Register Engine Central.registerEngineCentral( "com.sun.speech.freetts" + ".jsapi.FreeTTSEngineCentral"); // Create a Synthesizer Synthesizer synthesizer = Central.createSynthesizer( new SynthesizerModeDesc(Locale.US)); // Allocate synthesizer synthesizer.allocate(); // Resume Synthesizer synthesizer.resume(); // Speaks the given text // until the queue is empty. synthesizer.speakPlainText( response, null); synthesizer.waitEngineState( Synthesizer.QUEUE_EMPTY); System.out.println(response); }while(!request.equals("exit")); } catch (Exception e) { e.printStackTrace(); } } private static String getResourcesPath() { File currDir = new File("."); String path = currDir.getAbsolutePath(); path = path.substring(0, path.length() - 2); System.out.println(path); String resourcesPath = path + File.separator + "src" + File.separator + "main" + File.separator + "resources"; return resourcesPath; } }Step 12: Once code completed , then run the java program , type the input like Hai, hello and date, there are so many QA mentioned in imal files. and we can also write our own aiml file, for reference, you can verify under boats/aiml folder
Step 13: output will print in console and it will read the boat response..
Step 14: Out put will be like below image.
Friday, July 24, 2020
Angular with Spring boot Getting started with Angular and Spring boot
This post will explain , how we can integrate spring boot rest api in angular js
Step 1 : We need to install angular js
Follow the steps to mention in the angular web site Angular set up
Basic commands used in angular application
npm install -g @angular/cli
Create a new angular js application
ng new employee-crud-client
Once application created then, now we need to create components, services, model classes to integrate with spring boot
Step 2: to create component - Go to src/app folder in command prompt
ng g c employee-list
We can write our entire crud operations logic inside employee-list component or we can create different components for different operations.
Once we create component , there were 4 files created
1. employee-list.component.ts - logic related to how to form request and after getting the response from service- spring boot api, how to massage and send it to ui
2. employee-list.component.html - plain html with angular script to display/action with response or user input
3. employee-list.component.spec
4. employee-list.component.css
Step 3: Once the above files created and now we need to configure these with angular components
1. app.module.ts - will have the components, which we created
2. app-routing.module.ts- will have the path details, to which path has to call the which component
3. app.component.html - will have the router-outlet, which internally call the routing-module and which will call the app.modules.ts
Step 4: This is important step, service to be created, which calls the spring boot api
ng g s employee
employee.service file will be created
this service consists of the logic , how we can call the rest api methods, This is called from the employee-list.component.ts
Step 5: We will create model class, it should be same like our pojo class in java
ng g class employee
Step 6: Once all the steps completed, then now we need to run the angular client.
ng serve
ng serve --open If there is no errors, then page directly will open in browser http://localhost:4200
Step 7 : For spring boot api application, see my previous employee crud operations with spring boot post.
Step 8: This way we can integrate our spring boot application with angular.
Thanks for viewing this post, if you have any difficulty while integration, please comment the same.
Convert Date to Number and Number to Date in Oracle
How we can convert date to number in oracle
select to_number(to_char(add_months(sysdate,-0),'yyyymm')) from dual;
How we can convert number to date
select to_char(to_date(202007,'yyyymm'),'dd-mon-yyyy') from dual;
Subscribe to:
Posts (Atom)