|
Yes
System.ItDidntWorkException: Something didn't work as expected.
-- said no compiler, ever.
C# - How to debug code[ ^].
Seriously, go read this article.
Dave Kreskowiak
|
|
|
|
|
hi all
I have created in windows application and also one windows service using c#. this windows application has the database connection and do some functions etc which i want to daily repeat. so i have created the windows service. when i debug windows service in debug mode everything works fine. but after installation of windows service it is created the processes of that windows application. but that windows application is not initiating..
My Service code is:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Linq;
using System.ServiceProcess;
using System.Text;
using System.Timers;
using System.IO;
using System.Xml;
namespace OTMService
{
public partial class OTMService : ServiceBase
{
private Timer timer1 = null;
string tt1, tt2, tt3, tt4, tt5, tt6, thetime, time, tmp1, tmp0ch, basetmp, tmpAMPM;
int spp = 0, stime = 0;
public OTMService()
{
InitializeComponent();
}
protected override void OnStart(string[] args)
{
timer1 = new Timer();
this.timer1.Interval = 60000;
this.timer1.Elapsed += new System.Timers.ElapsedEventHandler(this.timer1_Tick);
timer1.Enabled = true;
Library.WriteErrorLog("Test window service started--Just Khan");
}
private void timer1_Tick(object sender, ElapsedEventArgs e)
{
mymainProg();
}
protected override void OnStop()
{
timer1.Enabled = false;
Library.WriteErrorLog("Test window service stopped--Just Khan-Service got stopped");
}
public void mymainProg()
{
string dirpath = AppDomain.CurrentDomain.BaseDirectory;
try
{
XmlDocument xmlDoc1 = new XmlDocument();
xmlDoc1.Load(dirpath+"OTMAppSetting.xml");
thetime = xmlDoc1.SelectSingleNode("Data/ServTime").InnerText;
tmp1 = thetime.Substring(3, 2);
tmp0ch = thetime.Substring(3, 1);
basetmp = thetime.Substring(0, 3);
tmpAMPM = thetime.Substring(6, 2);
spp = Convert.ToInt32(tmp1);
stime = checktime(spp);
if(tmp0ch=="0")
{
tt1 = basetmp + "0"+ stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt2 = basetmp + "0" + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt3 = basetmp + "0" + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt4 = basetmp + "0" + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt5 = basetmp + "0" + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt6 = basetmp + "0" + stime.ToString() + " " + tmpAMPM;
}
else
{
tt1 = basetmp + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt2 = basetmp + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt3 = basetmp + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt4 = basetmp + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt5 = basetmp + stime.ToString() + " " + tmpAMPM;
stime = stime + 1;
tt6 = basetmp + stime.ToString() + " " + tmpAMPM;
}
}
catch (Exception g)
{
Library.WriteErrorLog("Xml loading error for time: Error" + g.ToString());
}
DateTime dt = DateTime.Now;
time = dt.ToString("hh:mm tt");
if (time == tt1 || time == tt2 ||
time == tt3 || time == tt4 ||
time == tt5 || time == tt6)
{
try
{
Library.WriteErrorLog("Inside time and under try and catch Before Using");
foreach (var process in Process.GetProcessesByName("OTMBackendServiceExe"))
{
process.Kill();
}
using (Process pp = Process.Start(dirpath + "OTM_Plan_BackExe\\OTMBackendServiceExe.exe"))
{
int id = pp.Id;
Process tempProc = Process.GetProcessById(id);
Library.WriteErrorLog("Process completed all");
}
}
catch (Exception ex)
{
Library.WriteErrorLog("Main Exe cannot be started: " + ex.ToString());
}
}
}
private int checktime(int ss)
{
int theret = 0;
switch (ss)
{
case 54:
theret = ss - 2;
break;
case 55:
theret = ss - 3;
break;
case 56:
theret = ss - 4;
break;
case 57:
theret = ss - 5;
break;
case 58:
theret = ss - 6;
break;
case 59:
theret = ss - 6;
break;
default:
theret = ss;
break;
}
return theret;
}
}
}
and the windows application starting code:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Configuration;
using System.Xml.Linq;
using System.Xml;
using System.IO;
using Oracle.DataAccess.Client;
using Excel = Microsoft.Office.Interop.Excel;
using System.Net.Mail;
namespace OTMBackendServiceExe
{
public partial class Form1 : Form
{
string oraCstr, qrystr, qrystr1, OraCon, malstatus;
bool chk1 = false, chk2 = false;
int lcount = 0, chkkedd=0;
string empname, email_id, sup_email, cc_maillst, fcc_maillst, skilltype, product, skilltrack, current_level, target_level, tomail_sub;
string mailfor, otmmailbody, mail_sent_date, mail_sent_status, mailerr_msg;
string repformpath, repoutputpath, repfilename;
StringBuilder mlmsg = new StringBuilder();
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
WriteToFile("Testing: App Started");
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load("OTMAppSetting.xml");
oraCstr = "";
oraCstr = xmlDoc.SelectSingleNode("Data/DBstr").InnerText;
frommail = xmlDoc.SelectSingleNode("Data/frommmail").InnerText;
cc_maillst = xmlDoc.SelectSingleNode("Data/ccmaillst").InnerText;
WriteToFile("Started @:"+DateTime.Now.ToString());
nightqry();
allresettings();
skillupgrademail();
WriteToFile("Ended @:" + DateTime.Now.ToString());
Application.Exit();
}
in task manager it shows the process of that backend exe.
Need help. this backend exe is not getting executed when i run through service. if i run directly without any problem it runs.
Khan
|
|
|
|
|
Services can't start UI EXE apps directly: they are running on Session 0 and cannot create or display a UI at all.
I haven't tried it myself, but this may help: Subverting Vista UAC in Both 32 and 64 bit Architectures[^] - will it work in Win10? Dunno ...
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
Then do i have to create the console application instead of windows application to launch through service.
Khan
|
|
|
|
|
No. A Console app is also a UI app - not a GUI, but a UI. Services cannot interact with the desktop, or initiate any interaction - because they can be running before a user has logged in, so there is no user to interact with!
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
the app which is running at the backend through service doesn't have any user interaction. It just connect to database and run some procedures, get some rows from database and send mails to the participants.
Please suggest how to do that.
Khan
|
|
|
|
|
Make it a service as well...
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
You mean instead of creating another external exe whole code has to be written in service itself.
what i understood correct?
Khan
|
|
|
|
|
I have written all code of backend.exe file into service and it is working fine now. thanks a lot
Khan
|
|
|
|
|
You're welcome!
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
The comments about the UI in the other sub-thread, as far as I can tell, have no relevance to the code posted.
Presumably your log messages are showing up. Your code appears to be correctly handling potential exceptions HOWEVER you should log the stack trace also.
Finally, as to your problem...
Far as I can tell you do not seem to be actually starting the timer.
If true then what will happen is that your OnStart method will exit, which means no threads will be running in the service. Windows knows that threads are running and will not mark it as running unless one thread is running.
|
|
|
|
|
Any idea how to include thread in this service and backend.exe application
Khan
|
|
|
|
|
There are several ways. Your code is already mostly there except you are not starting the timer.
|
|
|
|
|
Looks like you're using Oracle.
In SQL Server, one just adds a (console) app to the server, and has it run on a schedule using SQL Server Agent. Easy.
One would think that Oracle has something similar. Or use the Windows Task Scheduler.
"(I) am amazed to see myself here rather than there ... now rather than then".
― Blaise Pascal
|
|
|
|
|
I'm searching for a good unit testing and mocking framework for C# (not necessarily open source).
Any suggestions?
|
|
|
|
|
I used to use nunit. Used to only because I haven't done any C# for a while. As long as it is being maintained I presume it is very usable.
I didn't use mocks then but googling certainly suggest that they exist.
|
|
|
|
|
For mocking, I love JustMock from Telerik. It allows you to mock things that other mocking frameworks just can't cope with.
This space for rent
|
|
|
|
|
|
How how can I download a PDF from PDF drive.net programmatically????
|
|
|
|
|
You will not get any help from this site to download illegally copied files: and that is exactly what the site you reference specializes in. The files it contains are copyrighted to the various authors and publishers and are effectively stolen.
Since we have many book authors here - and even more of us write technical documents and know exactly how hard it is to do - downloading books from illegal sites is not something we wish to be associated with.
Bad command or file name. Bad, bad command! Sit! Stay! Staaaay...
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
Hi everybody
I have a DataGrid control for which one of the columns consists in ComboBox controls defined in a DataTemplate (refer to the xaml snippet below).
The ComboBox controls are populated through data binding and everything works fine.
My problem: I would like to disable (from code behind) the selected ComboBox control item as long as the treatment associated to that selection is not complete.
Any idea, comment, suggestion?
Here is the xaml snippet:
<datagrid name="onGoingActionsGrid" autogeneratecolumns="False" background="Transparent" borderbrush="Transparent"
="" canuseraddrows="False" canuserdeleterows="False" canuserresizerows="False" canuserresizecolumns="False">
<datagrid.columns>
<datagridtextcolumn header="Actions" width="235" binding="{Binding Name}">
<datagridtemplatecolumn header="State" isreadonly="True" width="40">
<datagridtemplatecolumn.celltemplate>
<datatemplate>
<datagridtemplatecolumn header="Control" width="50">
<datagridtemplatecolumn.celltemplate>
<datatemplate>
<combobox x:name="ControlActionComboBox"
="" itemssource="{Binding CollectionOfPictograms, Mode=TwoWay}" selectionchanged="controlAction_SelectionChanged" selecteditem="{Binding SelectedItem, Mode=TwoWay}" selectedvaluepath="Content">
<combobox.itemcontainerstyle>
<Setter Property="Padding" Value="4.3"/>
<Setter Property="BorderBrush" Value="LightGray"/>
<Setter Property="BorderThickness" Value="1"/>
<combobox.itemtemplate>
<datatemplate>
<dockpanel>
|
|
|
|
|
You said you want to "disable" the combo box "item" ...
You can't disable "items"; you can only handle / not handle them explicitly.
As for "controls", add a bool "Enabled" property to the code-behind / view-model that has GET logic related the treatment and is bound to the .IsEnabled property of the control (i.e. combo) in the XAML.
"(I) am amazed to see myself here rather than there ... now rather than then".
― Blaise Pascal
|
|
|
|
|
(You should respond in the forums so everyone can see your answer).
Set the “IsEnabled” on the “combo box” in the XAML; not in the “item container” style.
Each “row” / item has it's own combo box (in this case).
"(I) am amazed to see myself here rather than there ... now rather than then".
― Blaise Pascal
|
|
|
|
|
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ConsoleApp2
{
class Program
{
static void Main(string[] args)
{
double wip;
double hii;
double bmi;
Console.Write("Eneter Weight in pounds:");
wip = Double.Parse(Console.ReadLine());
Console.Write("Enter height in inches:");
hii = Double.Parse(Console.ReadLine());
bmi = wip * 703 / Math.Pow(hii, 2);
Console.WriteLine($"bmi is: {bmi}");
Console.ReadLine();
if (bmi > 18.50)
{
Console.WriteLine("You are under weight.");
}
else if (bmi >= 24.9)
{
Console.WriteLine("Your weight is normal.");
}
else if (bmi > 30)
{
Console.WriteLine("You are obse.");
}
}
}
}
|
|
|
|
|
The BMI classification is defined like this:
- Underweight = <18.5
- Normal weight = 18.5-24.9
- Overweight = 25-29.9
- Obesity = >=30
(Source: Calculate Your BMI - Metric BMI Calculator[^])
To write that in your code, you can do this:
if (bmi < 18.5)
{
}
else if (bmi < 25)
{
}
else if (bmi < 30)
{
}
else
{
}
The quick brown ProgramFOX jumps right over the Lazy<Dog> .
|
|
|
|